• Privacywetgeving
    Het is bij Helpmij.nl niet toegestaan om persoonsgegevens in een voorbeeld te plaatsen. Alle voorbeelden die persoonsgegevens bevatten zullen zonder opgaaf van reden verwijderd worden. In de vraag zal specifiek vermeld moeten worden dat het om fictieve namen gaat.

Open van files in Excel Macro's

  • Onderwerp starter Onderwerp starter jost
  • Startdatum Startdatum
Status
Niet open voor verdere reacties.

jost

Gebruiker
Lid geworden
10 aug 2006
Berichten
34
Ik heb een uitgebreide macro opgezet, waarin hij verscheidene files opent. Nu loopt dit al 2 weken lekker; komt hij plotseling met de melding dat hij deze file niet kan openen. Terwijl ik niks veranderd heb in de macro, noch de filenaam....

Dit is mijn commando om hem te openen:

ChDir "X:\JV-Public\0. Funding Process\MGF (MGF FUNDS)\6. (MGF) Funding Program"
Workbooks.Open Filename:= _
"X:\JV-Public\0. Funding Process\MGF (MGF FUNDS)\6. (MGF) Funding Program\(XXXX.xls"

Wat doe ik fout?? Waarom pest excel mij zo.... :(
 
bestaat de drive op dat moment wel... heb je wel verbinding met die netwerkdrive op dat moment. En misschien ben je een haakje vergeten in:
"X:\JV-Public\0. Funding Process\MGF (MGF FUNDS)\6. (MGF) Funding Program\(XXXX.xls"

Overigens hoef je de actieve directory niet te wijzigen om een bestand te openen.

Code:
if Len(Dir("X:\JV-Public\0. Funding Process\MGF (MGF FUNDS)\6. (MGF) Funding Program\")) > 0 then
     Workbooks.Open Filename:= _
"X:\JV-Public\0. Funding Process\MGF (MGF FUNDS)\6. (MGF) Funding Program\XXXX.xls"
end if

op deze manier controleer je in ieder geval eerst of de map wel bestaat.

Wat doe ik fout?? Waarom pest excel mij zo.... :(
Omdat Excel een hekel heeft aan jou!
 
Gaat vooruit

ben er achter gekomen dat daar het probleem ligt, de ene keer herkent bij de folder wel als actief, en de andere keer niet. Het netwerk zal niet helemaal stabiel zijn? Of is de pathname gewoon te lang voor excel??

Heb nu tijdelijk het openen van files eruit gelaten en open de files handmatig van te voren. Schakelen tussen de 2 is niet zo lastig voor excel natuurlijk...

Is er niet een manier om de user te prompten handmatig de file te openen als de folder niet herkent wordt?

b v d
 
je kan het nog anders doen....
je hebt zo'n windows schermpje om een bestand te selecteren. een API heet dat.
Laat de gebruiker via dit scherm het bestand selecteren en open dit dan in excel
de code ziet er erg ingewikkeld ut maar is goed te gebruiken De auteurs zijn het KPD-team zoals vermeld.
Ik heb 3 regeltjes aangepast zodat het werkt in een Excel formulier
(om op excel bestande te filteren, de Hwnd op 0 gezet, App.hInstance verandert in Application.hInstance)

Code:
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
    nFilterIndex 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 Sub CommandButton1_Click()
'KPD-Team 1998
    'URL: http://www.allapi.net/
    'E-Mail: KPDTeam@Allapi.net
    Dim OFName As OPENFILENAME
    OFName.lStructSize = Len(OFName)
    'Set the parent window
    OFName.hwndOwner = 0
    'Set the application's instance
    OFName.hInstance = Application.hInstance
    'Select a filter
    OFName.lpstrFilter = "Excel Files (*.xls)" + Chr$(0) + "*.xls" + Chr$(0) + "All Files (*.*)" + Chr$(0) + "*.*" + Chr$(0)
    'create a buffer for the file
    OFName.lpstrFile = Space$(254)
    'set the maximum length of a returned file
    OFName.nMaxFile = 255
    'Create a buffer for the file title
    OFName.lpstrFileTitle = Space$(254)
    'Set the maximum length of a returned file title
    OFName.nMaxFileTitle = 255
    'Set the initial directory
    OFName.lpstrInitialDir = "C:\"
    'Set the title
    OFName.lpstrTitle = "Open File - KPD-Team 1998"
    'No flags
    OFName.flags = 0

    'Show the 'Open File'-dialog
    If GetOpenFileName(OFName) Then
        MsgBox "File to Open: " + Trim$(OFName.lpstrFile)
    Else
        MsgBox "Cancel was pressed"
    End If
End Sub
hopelijk kan je er wat mee
 
wil nog niet zo...

Heb het geprobeerd om in te voegen, maar dit gaat helaas iets boven mijn pet...

Zou je het anders in een excel bestandje aan kunnen leveren, want als ik dit in mijn macro kopieer, wil het niet werken...

Path name is: X:\JV-Public\0. Funding Process\LUX (AA LUX)\8. (LUX) Macro Program

en file name: (LUX) Prefunding

Voorlopig houd ik het op van te voren handmatig openen, al ben ik er niet zo blij mee. Maar een onstabiel programma heb ik ook niks aan. Ik ga hier namelijk over een paar weken weg, en moet het dan aan totale macro-leken achter laten...

Wederom bedankt
 
Status
Niet open voor verdere reacties.
Terug
Bovenaan Onderaan