IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VBScript Discussion :

objFile.Delete erreur Object required


Sujet :

VBScript

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut objFile.Delete erreur Object required
    L'avant dernière ligne donne une erreur et je n'arrive pas à trouver pourquoi ? (erreur : Object required objFile )

    Bien à vous

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
     
    Set objFSO = CreateObject("Scripting.FileSystemObject") 
    Set objFile2 = objFSO.GetFile("WordVBS.vbs") 
    FolderName=objFSO.GetParentFolderName(objFile2)&"\Word\" 
    For Each objFile In objFSO.GetFolder(FolderName).Files 
    Filename = objFSO.GetBaseName(objFile.Path)
    strCurrentExt = objFSO.GetExtensionName(objFile.Path) 
    next 
    PrinttemplateFolder=objFSO.GetParentFolderName(objFile2)&"\Printtemplate\"
    Set objWord = CreateObject("Word.Application")
    objWord.Visible = False
    Set objDoc= objWord.Documents.Open(Foldername&"rtf.rtf")
    Set objSelection= objWord.Selection
    objSelection.Wholestory()
    objSelection.copy()
    Set objWord1 = CreateObject("Word.Application")
    objWord1.Visible = False
    Set objDoc1 = objWord1.Documents.Add(PrinttemplateFolder&"printtemplate.dot")
    Set objSelection1= objWord1.Selection
    objSelection1.Paste()
    objDoc1.SaveAs(Foldername&Filename&".doc")
    ObjWord1.Quit
    ObjWord.Quit  
     
    For Each objFile In objFSO.GetFolder(FolderName).Files 
    strCurrentExt = objFSO.GetExtensionName(objFile.Path)   
    next
    If strCurrentExt = "rtf" Then 
    objFile.Delete
    End If

  2. #2
    Membre habitué
    Inscrit en
    Juin 2005
    Messages
    275
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 275
    Points : 186
    Points
    186
    Par défaut
    Citation Envoyé par chapeau_melon
    L'avant dernière ligne donne une erreur et je n'arrive pas à trouver pourquoi ? (erreur : Object required objFile )

    Bien à vous

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    For Each objFile In objFSO.GetFolder(FolderName).Files 
        strCurrentExt = objFSO.GetExtensionName(objFile.Path)   
    next
    If strCurrentExt = "rtf" Then 
        objFile.Delete
    End If
    objFile est défini dans ton "For Each". Sa portée s'arrête donc à Next, donc au moment où tu fais ton DELETE, il est considéré comme inexistant.

    Cela devrait fonctionner avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    For Each objFile In objFSO.GetFolder(FolderName).Files 
        strCurrentExt = objFSO.GetExtensionName(objFile.Path)   
        If strCurrentExt = "rtf" Then 
            objFile.Delete
        End If
    NEXT
    abertaud
    ---------

    - pas de réponse technique en PV, utilisez les forums
    - si vous trouvez seuls la solution, n'abandonnez pas votre post, mettez-le à jour pour les autres
    - le tag est parfois en voie d'extinction, participez à sa survie

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    hmm, quand je fais cela je reçoi comme erreur : Permission Denied : Line 29 Char 1 ?

  4. #4
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    et c'est laquelle la ligne 29 ..?

    à tu les droits pour effacer ce fichier ...? (affiche son nom pour être sur que c'est le bon .....)

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    La ligne 29 est encore avec objFile

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
     
    Set objFSO = CreateObject("Scripting.FileSystemObject") 
    Set objFile2 = objFSO.GetFile("WordVBS.vbs") 
    FolderName=objFSO.GetParentFolderName(objFile2)&"\Word\" 
     
    For Each objFile In objFSO.GetFolder(FolderName).Files 
    Filename = objFSO.GetBaseName(objFile.Path)
    strCurrentExt = objFSO.GetExtensionName(objFile.Path) 
    next 
     
    PrinttemplateFolder=objFSO.GetParentFolderName(objFile2)&"\Printtemplate\"
    Set objWord = CreateObject("Word.Application")
    objWord.Visible = False
    Set objDoc= objWord.Documents.Open(Foldername&"rtf.rtf")
    Set objSelection= objWord.Selection
    objSelection.Wholestory()
    objSelection.copy()
    Set objWord1 = CreateObject("Word.Application")
    objWord1.Visible = False
    Set objDoc1 = objWord1.Documents.Add(PrinttemplateFolder&"printtemplate.dot")
    Set objSelection1= objWord1.Selection
    objSelection1.Paste()
    objDoc1.SaveAs(Foldername&Filename&".doc")
    ObjWord1.Quit
    ObjWord.Quit  
     
    For Each objFile In objFSO.GetFolder(FolderName).Files 
    strCurrentExt = objFSO.GetExtensionName(objFile.Path)   
    If strCurrentExt = "rtf" Then 
    objFile.Delete
    End If
    next

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    J'ai trouvé, Le fichier étant toujours ouvert lors de manipulations, forcément l'accès est bloqué. Un pause à résolu le problème.

    Merci à tous

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    Set objFSO = CreateObject("Scripting.FileSystemObject") 
    Set objFile2 = objFSO.GetFile("WordVBS.vbs") 
    FolderName=objFSO.GetParentFolderName(objFile2)&"\Word\" 
    
    For Each objFile In objFSO.GetFolder(FolderName).Files 
    Filename = objFSO.GetBaseName(objFile.Path)
    next 
    
    PrinttemplateFolder=objFSO.GetParentFolderName(objFile2)&"\Printtemplate\"
    Set objWord = CreateObject("Word.Application")
    objWord.Visible = False
    Set objDoc= objWord.Documents.Open(Foldername&"rtf.rtf")
    Set objSelection= objWord.Selection
    objSelection.Wholestory()
    objSelection.copy()
    Set objWord1 = CreateObject("Word.Application")
    objWord1.Visible = False
    Set objDoc1 = objWord1.Documents.Add(PrinttemplateFolder&"printtemplate.dot")
    Set objSelection1= objWord1.Selection
    objSelection1.Paste()
    objDoc1.SaveAs(Foldername&Filename&".doc")
    ObjWord1.Quit
    ObjWord.Quit 
    
    WScript.Sleep 5000
    
    Set objFSO3 = CreateObject("Scripting.FileSystemObject")
    Set objFolder3 = objFSO3.GetFolder(FolderName)
    Set colFiles3 = objFolder3.Files
    for each objFile in colFiles3
    name3 = objFSO3.GetExtensionName(objFile)
    file3=objFSO3.GetFile(objFile)
    If name3 = "rtf" Then 
    objFSO3.DeleteFile(file3),True
    End If
    next

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Object required erreur avec sum if macro
    Par tuytuy dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 09/04/2013, 17h26
  2. erreur : Object required sur la fonction resizeTo sur IE7
    Par nakata77 dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 01/04/2010, 16h05
  3. [SWFObject 2.0] Erreur javascript "object required" dans IE6 et 7
    Par web_traveller dans le forum Intégration
    Réponses: 0
    Dernier message: 25/04/2008, 14h51
  4. [C#][debutant]erreur => object reference is required for a no
    Par ChristopheOce dans le forum Windows Forms
    Réponses: 3
    Dernier message: 25/01/2006, 13h47
  5. Erreur : '800a01a8' Object Required
    Par kiks dans le forum ASP
    Réponses: 4
    Dernier message: 01/12/2004, 13h58

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo