Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Access > Contribuez
Contribuez Access : Vos contributions. Postez ici vos codes sources, conseils, astuces et autres propositions. Ce forum n'est pas un forum technique mais destiné aux contributions pour www.developpez.com
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 01/03/2008, 18h36   #1
Expert Confirmé
 
Avatar de vodiem
 
Homme Diem VO
Vivre
Inscription : avril 2006
Messages : 2 644
Détails du profil
Informations personnelles :
Nom : Homme Diem VO
Âge : 40
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Vivre
Secteur : Conseil

Informations forums :
Inscription : avril 2006
Messages : 2 644
Points : 3 897
Points : 3 897
Par défaut [FAQ] [source] (lifting) de "Comment tester l'existence d'un fichier ?"

il y a qd même plus simple, plus rapide et plus sur que le code proposé dans la faq ici
là j'avais 10s sous la main:

Code :
1
2
3
Function existFile(ByVal fichier As String) As Boolean
existFile = Dir(fichier, vbNormal Or vbReadOnly Or vbHidden Or vbArchive) <> ""
End Function
d'ailleurs celui proposé ne fait pas de récursivité dans les sous sous... dossiers, seul les fichiers des sous dossiers de premier niveau sont explorés.
et je parle pas du fait qu'il ne parcours même pas les fichiers du dossier demandé mais uniquement ceux de ses sous dossiers de premier niveau!
et encore moins du "end" au lieu de "Exit For" qui annule le résultat si le fichier est trouvé!
pas bô tout ca...
vodiem est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/03/2008, 17h10   #2
Modérateur
 
Homme René MAROT
Inscription : octobre 2005
Messages : 5 491
Détails du profil
Informations personnelles :
Nom : Homme René MAROT
Localisation : Canada

Informations forums :
Inscription : octobre 2005
Messages : 5 491
Points : 7 588
Points : 7 588
Cette syntaxe est plus légère mais attention c'est du vieux stock :o) (ça vient du Gwbasic des années 1990). Il se peut quelle ne fonctionne pas correctement dans certains environnements plus modernes. Pour le moment je n'ai jamais expérimenté de problème avec mais il est bon de connaître l'autre syntaxe.

A+
__________________
Vous voulez une réponse rapide et efficace à vos questions téchniques ? Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
marot_r est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/03/2008, 20h02   #3
Expert Confirmé
 
Avatar de vodiem
 
Homme Diem VO
Vivre
Inscription : avril 2006
Messages : 2 644
Détails du profil
Informations personnelles :
Nom : Homme Diem VO
Âge : 40
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Vivre
Secteur : Conseil

Informations forums :
Inscription : avril 2006
Messages : 2 644
Points : 3 897
Points : 3 897
traite moi de ringard mais c'est dans les vieilles casseroles qu'on fait les meilleurs soupes. :p
les batchs n'ont pas encore disparu que je sache et cela marche toujours alors que les codes plus récents ne fonctionnent pas toujours.

mais si tu veux on peut faire plus long en plus récent:
Code :
1
2
3
4
5
Function existeFileFSO(ByVal fichier As String) As Boolean
Set fs = CreateObject("Scripting.FileSystemObject")
existeFileFSO = fs.FileExists(fichier)
Set fs = Nothing
End Function
ou encore plus récent (?):
Code :
1
2
3
4
5
6
7
8
Declare Function SearchPath Lib "kernel32" Alias "SearchPathA" (ByVal lpPath As String, ByVal lpFileName As String, ByVal lpExtension As String, ByVal nBufferLength As Long, ByVal lpBuffer As String, ByVal lpFilePart As String) As Long
 
Function existeFileSearchPath(ByVal chemin, fichier As String) As Boolean
    'Requires Windows Vista, Windows XP, or Windows 2000 Professional.
    Dim ResultFileName As String
    Dim pFilePart As Long
    existeFileSearchPath = SearchPath(chemin, fichier, vbNullString, 1, ResultFileName, pFilePart) > 0
End Function
et je ne doute pas que l'on trouve d'autres façons de faire avec des "Open" ou à partir d'autres objets.
je voulais simplement faire court et je ne doute pas que cela marchera encore avant ma mort: je le jure sur ma tête.

vodiem est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/03/2008, 20h32   #4
Modérateur
 
Homme René MAROT
Inscription : octobre 2005
Messages : 5 491
Détails du profil
Informations personnelles :
Nom : Homme René MAROT
Localisation : Canada

Informations forums :
Inscription : octobre 2005
Messages : 5 491
Points : 7 588
Points : 7 588
Citation:
Envoyé par vodiem Voir le message
traite moi de ringard mais c'est dans les vieilles casseroles qu'on fait les meilleurs soupes. :p
Que neni messire, j'utilise généralement Dir et Open que je trouve beaucoup plus clair et surtout que je connais mieux (c'est pas pour rien que je peux dire de quand elles datent).

Mais par exemple marchent-elles si tu veux faire un test sur fichier situé sur un serveur distant sans mapping disque ?

Merci pour tes syntaxes plus récentes, je vais me les imprimer.

A+
__________________
Vous voulez une réponse rapide et efficace à vos questions téchniques ? Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
marot_r est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/03/2008, 21h34   #5
Expert Confirmé
 
Avatar de vodiem
 
Homme Diem VO
Vivre
Inscription : avril 2006
Messages : 2 644
Détails du profil
Informations personnelles :
Nom : Homme Diem VO
Âge : 40
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Vivre
Secteur : Conseil

Informations forums :
Inscription : avril 2006
Messages : 2 644
Points : 3 897
Points : 3 897
oui, je viens de faire les tests sur un serveur distant sans mapping disque: les trois fonctions... fonctionnent.

mais j'irais pas pousser à faire une fonction autorisant d'une session avec restriction à connaitre l'existance d'un fichier sur un dossier demandant certains pouvoirs par login et mot de passe...
vodiem est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/03/2008, 21h56   #6
Rédacteur
 
Avatar de LedZeppII
 
Homme
Maintenance données produits
Inscription : décembre 2005
Messages : 3 941
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Maintenance données produits
Secteur : Distribution

Informations forums :
Inscription : décembre 2005
Messages : 3 941
Points : 6 283
Points : 6 283
Le nom vieillot faisant référence à la commade du même nom sous DOS (et CMD) et sa syntaxe simplissime sont à mon avis trompeurs
Le Dir de VBA n'est pas le Dir de l'interpréteur de commande CMD.
A mon avis la fonction Dir de VBA utilise l'API Windows et évolue au fil des changements de Windows.
Sinon on ne pourrait l'utiliser qu'avec des noms de fichiers courts (8+3).

La conclusion c'est que Dir de VBA et FileExists de Scripting.FileSystemObject permettent de tester l'existance d'un fichier plus simplement que la solution proposée dans la faq.

Vodiem : As-tu contacté le responsable de la faq par MP pour signaler ce problème ?

A+
LedZeppII est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2008, 10h06   #7
Expert Confirmé
 
Avatar de vodiem
 
Homme Diem VO
Vivre
Inscription : avril 2006
Messages : 2 644
Détails du profil
Informations personnelles :
Nom : Homme Diem VO
Âge : 40
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Vivre
Secteur : Conseil

Informations forums :
Inscription : avril 2006
Messages : 2 644
Points : 3 897
Points : 3 897
salut ledZeepII,
Citation:
Envoyé par ledZeepII
Le Dir de VBA n'est pas le Dir de l'interpréteur de commande CMD.
A mon avis la fonction Dir de VBA utilise l'API Windows et évolue au fil des changements de Windows.
Sinon on ne pourrait l'utiliser qu'avec des noms de fichiers courts (8+3).
ce n'est pas exacte pour le dir du dos qui a dès le début intégré les noms de fichiers long dès la première version de win qui l'a géré.
mais tu as surement raison, pour ce qui est de l'évolution de la fonction dir de vba qui comme sous dos évolue (sinon en mode console on pourrait même pas adresser les nouvelles limitations de disque ce qui poserait un sérieux problème de maintenance).
donc de là à dire que les commandes dos sont différents de ceux de windows (vba & Co.), je doute: ils doivent tous finir au même driver.
Je dirais donc vieux mais bien conservé, comme nous...

ps: pour la faq, non. d'ailleurs je n'ai pas trouvé d'endroit sur dvp (j'ai pas beaucoup cherché non plus) où l'on retrouve un organigramme des responsables. il serait bien d'ailleurs d'afficher les responsables de forum pour chaque forum.
vodiem est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2008, 10h09   #8
Rédacteur/Modérateur
 
Avatar de Philippe JOCHMANS
 
Homme Philippe JOCHMANS
Développeur informatique
Inscription : mai 2005
Messages : 17 625
Détails du profil
Informations personnelles :
Nom : Homme Philippe JOCHMANS
Âge : 44
Localisation : France, Loir et Cher (Centre)

Informations professionnelles :
Activité : Développeur informatique
Secteur : Communication - Médias

Informations forums :
Inscription : mai 2005
Messages : 17 625
Points : 30 907
Points : 30 907
Envoyer un message via MSN à Philippe JOCHMANS Envoyer un message via Skype™ à Philippe JOCHMANS
Bonjour

Je vais signaler ceci au responsable de la FAQ Access, il est trés pris cette semaine, mais il sera au courant.



Starec
__________________
Détaillez vos questions, sinon vous aurez des réponses erronées et vous irez tout droit dans le et lisez les règles sinon
Si vous pensez commencer sans un livre, oublier : livres pour débuter
Vous pouvez consulter mes articles sur Access et PowerPoint
Le blog Office.
Philippe JOCHMANS est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2008, 22h12   #9
Rédacteur
 
Avatar de LedZeppII
 
Homme
Maintenance données produits
Inscription : décembre 2005
Messages : 3 941
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Maintenance données produits
Secteur : Distribution

Informations forums :
Inscription : décembre 2005
Messages : 3 941
Points : 6 283
Points : 6 283
Bonsoir,

En tout début de la faq il y a un lien vers le responsable : http://www.developpez.net/forums/u47206/dolphy35/

Citation:
ce n'est pas exacte pour le dir du dos qui a dès le début intégré les noms de fichiers long dès la première version de win qui l'a géré
Effectivement je vois que j'ai mal formulé ce que je voulais dire.
Comme marot_r parlait d'une technologies des années 90 je pensais plus à un DOS 6.
Mais j'ai parlé de CMD, ce qui ne colle pas.

Est-ce que les utilisateurs d'Office pour Mac s'inquiètent d'utiliser une fonction s'appelant Dir dans VBA ?
Si oui, il seront embêtés pour trouver du "Scripting.FileSystemObject"
Ce que je veux dire, c'est que le code source de la fonction VBA Dir est certainement adapté au mieux pour la plateforme où elle va s'exécuter.
Pourquoi ils s'embêteraient à maintenir une fonction compatible DOS alors qu'Office ne tourne pas sous DOS ?

A+
LedZeppII est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/03/2008, 09h59   #10
Rédacteur
 
Avatar de Lou Pitchoun
 
Christophe Lessirard
Inscription : février 2005
Messages : 5 029
Détails du profil
Informations personnelles :
Nom : Christophe Lessirard
Âge : 33
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2005
Messages : 5 029
Points : 6 000
Points : 6 000
Envoyer un message via MSN à Lou Pitchoun
Citation:
Envoyé par vodiem Voir le message
ps: pour la faq, non. d'ailleurs je n'ai pas trouvé d'endroit sur dvp (j'ai pas beaucoup cherché non plus) où l'on retrouve un organigramme des responsables. il serait bien d'ailleurs d'afficher les responsables de forum pour chaque forum.
La création d'une page team Office est en cours.

__________________

Access : Les Cours, Les Sources et Les FAQs Office
Avant de poster : les choses importantes à lire pour la bonne tenue du forum.
sinon

Ma boite à MPs n'est pas l'annexe du forum Le complément BouleDeCristal n'existe pas encore !!!
Lou Pitchoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 08h02.


 
 
 
 
Partenaires

Hébergement Web