MERHABA BİR Access PROJEM VAR. Excel IMPORT ETME BUTONU OLACAK VE KULLANICI BUTONA TIKLAYIP "İSTEDİĞİ Excel DOSYASINI" IMPORT EDECEK. BUNU FORM OLUŞTURARAK Vba İLE YAPACAĞIM GALİBA. YARDIMLARINIZ İÇİN ŞİMDİDEN TEŞEKKÜR EDİYORUM.
ACCESS'E EXCEL IMPORT ETME BUTONU
Merhaba.
Eğer seçilecek Excel dosyası belli ise:
Seçilecek Excel dosyasını "Dosya Aç" dialog kutusu vasıtası ile seçmek için:
Yalnız her iki durumda da veri alınacak tablo adı belli olmalı.
Veri alınacak tablo Access veritabanında yok ise oluşturulur, var ise veriler veritabanına eklenir, yalnız alınacak Excel tablosundaki ve eklenecek veritabanındaki alan başlıkları farklı olmamalı, yoksa hata verir.
Eğer seçilecek Excel dosyası belli ise:
DoCmd.TransferSpreadsheet acImport, acSpreadsheetTypeExcel9, "Tablo_Adi", "Excel_Dosyasi_Yolu_ve_Adi", True
Seçilecek Excel dosyasını "Dosya Aç" dialog kutusu vasıtası ile seçmek için:
Private Secilen As String
Private Declare Function GetOpenFileName Lib "comdlg32.dll" Alias "GetOpenFileNameA" (pOpenfilename As OpenFilename) As Long
Private Type OpenFilename
lStructSize As Long
hwndOwner As Long
hInstance As Long
lpstrFilter As String
lpstrCustomFilter As String
nMaxCustFilter As Long
iFilterIndex As Long
lpstrFile As String
nMaxFile As Long
lpstrFileTitle As String
nMaxFileTitle As Long
lpstrInitialDir As String
lpstrTitle As String
Flags As Long
nFileOffset As Integer
nFileExtension As Integer
lpstrDefExt As String
lCustData As Long
lpfnHook As Long
lpTemplateName As String
End Type
Private Function DosyaAcFonksiyonu() As String
Dim Secilenin As OpenFilename
Secilenin.lStructSize = Len(Secilenin)
Secilenin.hwndOwner = hwnd
Secilenin.lpstrFilter = "Excel Dosyaları (*.xls*)" & Chr$(0) & "*.xls" & Chr$(0) & Chr(0) & Chr(0)
Secilenin.lpstrFile = String(256, 0)
Secilenin.nMaxFile = 255
Secilenin.lpstrTitle = "Dosya Aç"
Secilenin.Flags = &H800000 + &H1000 + &H8 + &H4
GetOpenFileName Secilenin
If Mid(Secilenin.lpstrFile, 1, 1) <> Chr(0) Then DosyaAcFonksiyonu = Secilenin.lpstrFile
Secilen = Secilenin.lpstrFile
End Function
Private Sub Komut0_Click()
Dim Dosya As String
Dosya = DosyaAcFonksiyonu
If Dosya <> "" Then DoCmd.TransferSpreadsheet acImport, acSpreadsheetTypeExcel9, "Tablo_Adi", Dosya, True
End Sub
Yalnız her iki durumda da veri alınacak tablo adı belli olmalı.
Veri alınacak tablo Access veritabanında yok ise oluşturulur, var ise veriler veritabanına eklenir, yalnız alınacak Excel tablosundaki ve eklenecek veritabanındaki alan başlıkları farklı olmamalı, yoksa hata verir.
Mesajlarımızı Türkçe yazım kurallarına uygun yazalım.
Emeğe saygı gösterelim, bir teşekkürü çok görmeyelim.
Emeğe saygı gösterelim, bir teşekkürü çok görmeyelim.
Bu kodu butonun tıklandığı olayına mı koyacağız acaba dosya adından başka değiştireceğimiz yer varmıdır?
Seçilecek Excel dosyasını "Dosya Aç" dialog kutusu vasıtası ile seçmek için:
Yalnız her iki durumda da veri alınacak tablo adı belli olmalı.
Veri alınacak tablo Access veritabanında yok ise oluşturulur, var ise veriler veritabanına eklenir, yalnız alınacak Excel tablosundaki ve eklenecek veritabanındaki alan başlıkları farklı olmamalı, yoksa hata verir.
[/quote]
Seçilecek Excel dosyasını "Dosya Aç" dialog kutusu vasıtası ile seçmek için:
Private Secilen As String
Private Declare Function GetOpenFileName Lib "comdlg32.dll" Alias "GetOpenFileNameA" (pOpenfilename As OpenFilename) As Long
Private Type OpenFilename
lStructSize As Long
hwndOwner As Long
hInstance As Long
lpstrFilter As String
lpstrCustomFilter As String
nMaxCustFilter As Long
iFilterIndex As Long
lpstrFile As String
nMaxFile As Long
lpstrFileTitle As String
nMaxFileTitle As Long
lpstrInitialDir As String
lpstrTitle As String
Flags As Long
nFileOffset As Integer
nFileExtension As Integer
lpstrDefExt As String
lCustData As Long
lpfnHook As Long
lpTemplateName As String
End Type
Private Function DosyaAcFonksiyonu() As String
Dim Secilenin As OpenFilename
Secilenin.lStructSize = Len(Secilenin)
Secilenin.hwndOwner = hwnd
Secilenin.lpstrFilter = "Excel Dosyaları (*.xls*)" & Chr$(0) & "*.xls" & Chr$(0) & Chr(0) & Chr(0)
Secilenin.lpstrFile = String(256, 0)
Secilenin.nMaxFile = 255
Secilenin.lpstrTitle = "Dosya Aç"
Secilenin.Flags = &H800000 + &H1000 + &H8 + &H4
GetOpenFileName Secilenin
If Mid(Secilenin.lpstrFile, 1, 1) <> Chr(0) Then DosyaAcFonksiyonu = Secilenin.lpstrFile
Secilen = Secilenin.lpstrFile
End Function
Private Sub Komut0_Click()
Dim Dosya As String
Dosya = DosyaAcFonksiyonu
If Dosya <> "" Then DoCmd.TransferSpreadsheet acImport, acSpreadsheetTypeExcel9, "Tablo_Adi", Dosya, True
End Sub
Yalnız her iki durumda da veri alınacak tablo adı belli olmalı.
Veri alınacak tablo Access veritabanında yok ise oluşturulur, var ise veriler veritabanına eklenir, yalnız alınacak Excel tablosundaki ve eklenecek veritabanındaki alan başlıkları farklı olmamalı, yoksa hata verir.
[/quote]
Ayrıca ben formda bir buton yaptım tıklandığı olayına
Private Sub Komut0_Click()
CurrentDb.Execute “Delete *From tablo_adi”
CurrentDb.Execute “ INSERT INTO tablo_adi [kimlik],[tarihi]) SELECT M5. [kimlik],M5.[tarihi] FROM [M5]”
Form.Requvery
End Sub
Bunu yazdın M5=bağlı Excel tablom
Verileri güzelce aktarıyorum. Ancak bağlı tablonun çektiği Excel dosyasının yolu başka pc de bulamıyor.Bunu kullanıcıya seçtirmek isterim. Yardımlarınızı bekliyorum.
Private Sub Komut0_Click()
CurrentDb.Execute “Delete *From tablo_adi”
CurrentDb.Execute “ INSERT INTO tablo_adi [kimlik],[tarihi]) SELECT M5. [kimlik],M5.[tarihi] FROM [M5]”
Form.Requvery
End Sub
Bunu yazdın M5=bağlı Excel tablom
Verileri güzelce aktarıyorum. Ancak bağlı tablonun çektiği Excel dosyasının yolu başka pc de bulamıyor.Bunu kullanıcıya seçtirmek isterim. Yardımlarınızı bekliyorum.
Konuyu Okuyanlar: 1 Ziyaretçi