Avatar billede balderk Nybegynder
23. september 2009 - 12:42 Der er 2 kommentarer

Import fra eet ark i flere excel-filer i een mappe.

Jeg har en en række data i forskellige filer, jeg skal have samlet i een tabel i Access.
Det skal i første omgang kun gøres een gang, men der er for mange filer og data til at jeg orker at gøre det manuelt - og lur mig om jeg ikke kommer til at skulle gøre det igen.

Så jeg leder efter en VBA-løsning til at gøre det. Jeg har lavet en del VBA, men mere data end filer.

Jeg har:
Access '97.
-Een mappe (c:\journaler)
-Med flere excel filer (å20090501.xls, å20090512.xls...)
-Hver af disse har eet ark, hvor navnet starter med "DKDCPC"

Alle data skal med, og de har samme form - dog med overskriftslinie.
Der ligger andre filer i mappen, men de starter ikke med "å", og hvis lettere kan jeg bare flytte disse et andet sted hen.

pft.
Avatar billede mugs Novice
24. september 2009 - 10:35 #1
Prøv at lege lidt med denne:

Private Sub Kommandoknap16_Click()
Dim VARa As String
VARa = InputBox(Prompt:="Indtast stien til Excel-arket.", Title:="Hvor ligger Excel-filen?", Default:="c:\journaler\DKDCPCxxx")
DoCmd.SetWarnings False
DoCmd.TransferSpreadsheet acImport, 0, "Importtest", VARa, False, ""
MsgBox "Importen er udført."
End Sub

Du importerer simpelthen den fil der er angivet i inoutboksen. Jeg har givet boksen en default værdi. Den er hentet fra en 2003 db, men så vidt jeg husker er den oprindelig lavet i Acc97.
Avatar billede balderk Nybegynder
24. september 2009 - 18:18 #2
Det bragte mig et godt stykke af vejen, men jeg kan ikke få den til at acceptere wildcards for arknavne (DKDCPCxxxx).
Jeg fik flækket nedenstående sammen, men det er hverken pænt eller hurtigt.
Jeg ville helst undgå, at skulle være nødt til at åbne hver eneste fil og løbe den igennem for at finde det rigtige ark.

Private Sub Kommandoknap16_Click()

'Fra http://www.accessmvp.com/KDSnell/EXCEL_Import.htm#ImpWktFilesSepTbls


Dim blnHasFieldNames As Boolean
Dim strWorksheet As String, strTable As String
Dim strPath As String, strPathFile As String
Dim ws As Excel.worksheet
Dim appExcel As Excel.Application
Dim wb As Workbook



' Change this next line to True if the first row in EXCEL worksheet
' has field names
blnHasFieldNames = True

' Replace C:\Documents\ with the real path to the folder that
' contains the EXCEL files
strPath = "C:\Documents and Settings\dkdcbk\Skrivebord\Journaler\"

' Replace worksheetname with the real name of the worksheet that is to be
' imported from each file
strWorksheet = "DKDCPC"

' Import the data from each workbook file in the folder
strFile = Dir(strPath & "*.xls")

Set appExcel = CreateObject("Excel.Application")

Do While Len(strFile) > 0
      strPathFile = strPath & strFile
      strTable = "tbl_" & strWorksheet
       
       
        Set wb = appExcel.Workbooks.Open(strPathFile)
        For Each sh In wb.Sheets
        If Left(sh.Name, 6) = strWorksheet Then
   
            DoCmd.TransferSpreadsheet acImport, _
                  acSpreadsheetTypeExcel9, strTable, strPathFile, _
                  blnHasFieldNames, sh.Name & "$", False

        End If
        Next
 
    strFile = Dir()
    wb.Close

     
Loop

    appExcel.Quit
       
End Sub
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Dyk ned i databasernes verden på et af vores praksisnære Access-kurser

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester



IT-JOB

Udviklings- og Forenklingsstyrelsen

Scrum Master

Sparekassen Danmark

RPA-udvikler til IT-afdelingen

Udviklings- og Forenklingsstyrelsen

Kontorchef med ansvar for tværgående service management

Netcompany A/S

Network Engineer