Macro pour enregistrer sur clé usb

Fermé
waea - 27 janv. 2010 à 18:57
waea Messages postés 42 Date d'inscription lundi 18 janvier 2010 Statut Membre Dernière intervention 31 août 2015 - 1 févr. 2010 à 11:17
Bonjour,
voilà mon petit problème : je n'arrive pas à écrire une macro qui me permettre d'enregistrer un fichier excel sur une clé usb dont la lettre peut changer (F,G ...;) tout cela relié à un petit bouton.
le fichier à enregistrer est un fichier xlsm, donc qui fonctionne avec macros

quelqu'un peut-il m'aider à résoudre cette énigme ??
merci d'avance
A voir également:

13 réponses

michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
27 janv. 2010 à 19:17
bonsoir

fonction pour connaitre la lettre de l'usb connectée

Function lettre_usb()
ordi = "."
Set objet_WMI = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" & ordi & "\root\cimv2")
Set liste_pilotes = objet_WMI.ExecQuery _
    ("Select * from Win32_LogicalDisk")
For Each pilote In liste_pilotes
    If pilote.DriveType = 2 Then
        lettre_usb = pilote.DeviceID
        Exit Function
    End If
Next
lettre_usb = "aucune clé connectée"
End Function

Sub test()
msgbox lettre_usb

End Sub
1
Le Pingou Messages postés 12225 Date d'inscription mercredi 11 août 2004 Statut Contributeur Dernière intervention 6 décembre 2024 1 452
28 janv. 2010 à 22:06
Bonjour michel_m,
Je viens de faire un essai de cette procédure et dans mon cas je reçois toujours le lettre
[A:] alors que la clef se trouve en [G:] !
C'est ou l'astuce ?
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435 > Le Pingou Messages postés 12225 Date d'inscription mercredi 11 août 2004 Statut Contributeur Dernière intervention 6 décembre 2024
28 janv. 2010 à 22:43
Bonsoir Jean-Pierre, michel_m
le code de michel_m est correct, il detecte le premier "removable disk" (drivetype = 2) connecté(mais ça peut etre autre chose, windows ne fait pas réellement la différence entre un disque externe, un lecteur de cartes memoire ou même un lecteur de disquette connecté en usb - c tout du 'disque amovible')...la question qui se pose c'est à quoi correspond ce lecteur A: sur ta machine ?
0
Le Pingou Messages postés 12225 Date d'inscription mercredi 11 août 2004 Statut Contributeur Dernière intervention 6 décembre 2024 1 452 > tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013
28 janv. 2010 à 23:28
Bonsoir tompols,
Merci infiniment pour l'explication qui renforce se que j'ai découvert entre temps.
0
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310 > Le Pingou Messages postés 12225 Date d'inscription mercredi 11 août 2004 Statut Contributeur Dernière intervention 6 décembre 2024
29 janv. 2010 à 09:11
Bonjour,

Pour notre culture informatique
vbscript (trouvé sur le net de la liste des pilotes). Il faut que le composant soit installé pour être pris compte

strComputer = "."
Set objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")

Set colDisks = objWMIService.ExecQuery _
    ("Select * from Win32_LogicalDisk")

For Each objDisk in colDisks
    Wscript.Echo "DeviceID: "& objDisk.DeviceID
    Select Case objDisk.DriveType
        Case 1
            Wscript.Echo "No root directory. Drive type could not be " _
                & "determined."
        Case 2
            Wscript.Echo "DriveType: "& "Removable drive."
        Case 3
            Wscript.Echo "DriveType: "& "Local hard disk."
        Case 4
            Wscript.Echo "DriveType: "& "Network disk."
        Case 5
            Wscript.Echo "DriveType: "& "Compact disk."
        Case 6
            Wscript.Echo "DriveType: "& "RAM disk."
        Case Else
            Wscript.Echo "Drive type could not be determined."
    End Select
Next


ainsi at home la clé USB se trouve sur le lecteur G: et le dd externe sur H:
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435 > michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023
29 janv. 2010 à 09:14
Bonjour michel_m,
"il faut que le composant soit installé", de quel composant parles-tu ?
0
waea Messages postés 42 Date d'inscription lundi 18 janvier 2010 Statut Membre Dernière intervention 31 août 2015
27 janv. 2010 à 19:24
Bonsoir et merci d'avoir répondu...............mais

pour gagner en précision, voiçi ce que je souhaiterais ;

une boite de dialogue qui me connecte de suite sur la clé usb et sur le fichier en question
avec la possibilité de changer le nom du fichier si par hasard je voulais en avoir plusieurs pour différentes raisons
ensuite, évidemment la boite de dialogue étant standard, je n' aurais plus qu'à enregistrer mon travail

j'espère que tout cela est plus clair

merci d'avance
0
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
28 janv. 2010 à 08:07
Bin, c'est du vba de base !
tu as la lettre, tu connais le chemin dans ta clé, donc tu utilises open filename
ou tu changes de pilote par
chdir la letttre usb
puis get openfilename tu peux faire ca avec l'enregistreur de macros...
0
waea Messages postés 42 Date d'inscription lundi 18 janvier 2010 Statut Membre Dernière intervention 31 août 2015
28 janv. 2010 à 17:50
Bonjour,

merci tout d'abord, mais il me serait agréable d'avoir une idée du code écrit dans le cas où la lettre de la clé pourrait changer!
tout cela avec les infos que j'ai donné plus haut

merci encore
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
28 janv. 2010 à 22:21
Bonsoir,
souhaites-tu sauvegarder tjs sur la meme clé ? ds ce cas on pourrait utiliser le nom de la clé, comme ici....
sinon on peut aussi sauvegarder sur la premiere clé USB détectée (au cas où y'en aurait plusieurs, mais si y'a un disque externe ça risque de passer dessus également) qui soit "writable" (cas d'une clé protégée)....pour eviter l'hsitoire du disque externe on peut aussi imaginer sauvegarder ds un dossier précis (du coup s'il est absent c pas le bon disque...)...bref, plein de trucs (en passant tres probablement par wmi comme michel_m le propose)...dis-nous....
0
waea Messages postés 42 Date d'inscription lundi 18 janvier 2010 Statut Membre Dernière intervention 31 août 2015
29 janv. 2010 à 11:23
bonjour,

j'ai essyé le code de michel_m mais cela bloque ici
Wscript.Echo "DeviceID: " & objDisk.DeviceID

de plus ma clé est en G mais elle pourrait être aussi en F..........alors que puis_je faire?
je bloque là !

merci d'avance
waea
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
29 janv. 2010 à 12:16
Bonjour,
si tu veux utiliser le code de michel_m, utilises le premier, le second est un vbs...
As-tu regardé le lien de mon post 6 ? peux-tu stp répondre à ces questions (en gros comment repérer la clé usb, car il existe bcp de types de "disques amovibles" en windows ne fait pas la différence....) ?
0
waea Messages postés 42 Date d'inscription lundi 18 janvier 2010 Statut Membre Dernière intervention 31 août 2015
29 janv. 2010 à 15:08
bonjour,

après essai du 1er code cela me donne une boite de dialogue avec F reconnu pour ma clé usb insérée.
mais je ne peux rien faire de plus..........ni copier le classeur avec macros ni rien du tout !

help me please !

waea
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
29 janv. 2010 à 15:49
Re,
tu ne reponds toujours pas à mes questions....ton probleme est mal énoncé (ou pas comptement) ! que fait-on si plusieurs clés usb branchées (plusieurs 'disques amovibles'), comment repere-t-on la clé sur laquelle sauvegarder, on prend n'importe laquelle (au risque d'écrire sur un disque externe ou une cate sd ou autre) ? ensuite si tu veux qu'on ecrive tout le code pour toi j'aurais tendance à dire faut pas pousser, un peu de recherche et tu devrais t'en sortir pour trouver le code pour sauvegarder (en meme tps, jsuis gentil aujourd'hui, si tu réponds aux questions ptet bien que jte ferai ça...)
"help me please ! " => bah écoute, là jfais ce que je peux mais c'est toi qui ne m'aide pas à t'aider :p
0
Bonjour et pardon si je vous ai froissé.............je n'avais pas pris le temps de bien comprndre vos demandes !
en fait, il n'y a qu'une clé de brancher et elle peut porter soit la lettre F soit la lettre G dans le cas d'une autre clé qui comporte une partie sur laquelle je peux mettre des données .
je ne mesurais pas que la lettre de la clé pouvait avoir une importance.
dans le cas ou il est plus facile de n'avoir qu'une lettre alors il faudrait chosiir G.
j'avais bien toruver un code qui me permettait de transférer le fichier, mais je ne pouvais pas l'ouvrir ensuite de la dite clé???????????
on me disait que le fichier n'était pas reconnu.............donc mon code très simple ne fonctionne pas. c'est pourquoi je fais appel à vous.
je me rend compte que je vous demande beaucoup et si vous ne voulez pas poursuivre je le comprendrais fort bien !
vous avez déjà fait beaucoup
est-ce que ces informations vous conviennent ?
cordialement
waea
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
30 janv. 2010 à 15:38
Re, pas de souci je ne suis pas "froissé", ptet juste un peu frustré, je sens que la solution est pas loin mais il manque des éléments et on y arrive pas....
Bon alors ,je ré-explique, la difficulté ici consiste à etre sur d'enregistrer sur le bon "disque amovible" car c'est ainsi que windows reconnait les clés usb mais aussi un tas d'autres trucs comme par ex un disque dur ou meme un lecteur mp3 ou encore un appareil photo dans certains cas....il nous faut donc trouver un moyen d'identifier la clé usb sur laquelle enregistrer au cas ou plusieurs appareils soient branchés, cela peut etre le nom de la clé USB, un fichier ou dossier déjà présent sur la clé ou autre...
Je te propose ceci :
1 - il faut que tu reperes le nom de ta clé usb (ce qui s'affiche dans poste de travail), si elle n'a pas de nom ("disque amovible") donnes lui en un..
2 ensuite tu colles ce code ds ton fichier excel en adaptant le nom de ta clé (dans mon cas j'avais mis USB TOM):
Sub usbtransfer()

strComputer = "."
Set objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")

Set colDisks = objWMIService.ExecQuery _
    ("SELECT * FROM Win32_LogicalDisk WHERE DriveType = 2", , 48)

For Each objdisk In colDisks
If objdisk.VolumeName = "USB TOM" Then
rdrive = objdisk.deviceid & "\"
End If
Next objdisk

ActiveWorkbook.SaveAs rdrive & ActiveWorkbook.Name

End Sub

Sil la solution avec le nom ne convient pas, il faudra trouver un autre moyen d'etre sur qu'on est sur le bon périphérique usb (présence d'un fichier/dossier?)....
0
Tompols bonjour

tout d'abord merci infiniment ! je viens d'essayer et ça marche !
je suppose que si j'apporte des modifications au fichier, lorsque je demande une nouvelle sauvegarde sur la clé j'aurais un message ( classique) me demandant si je veux remplacer le fichier existant ?
waea
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
30 janv. 2010 à 16:08
Re,
oui, mais on peut ne pas afficher ce message en remplaçant :
ActiveWorkbook.SaveAs rdrive & ActiveWorkbook.Name

par :
Application.DisplayAlerts = False
ActiveWorkbook.SaveAs rdrive & ActiveWorkbook.Name
Application.DisplayAlerts = True
0
re bonjour,

en fait en essayant votre code tout c'est bien passé sur la clé puis j'ai fermé excel et lors d'un redémarrage de windows j'ai eu un écran bleu me signifiant un arrêt non planifié de windows.
il fallait que je choisisse une option : sans échec, etc.... windows normal

pouvez vous m'expliquez ce que cela signifie ?
pour moi cela vient de la procédure qui surement pose un petit pb à windows.
sans doute une manipulation que je dois faire en plus?

merci d'avance
waea
0
Le Pingou Messages postés 12225 Date d'inscription mercredi 11 août 2004 Statut Contributeur Dernière intervention 6 décembre 2024 1 452
31 janv. 2010 à 19:34
Bonjour,
Petit conseil, lorsque l’on travaille avec une clef USB, avant de l'enlever, il est recommandé de passer par le poste de travail et un clic droit sur le périphérique concerné et clic [Ejecter].
Faites un essai pour voir si le probéme est à se niveau.
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
1 févr. 2010 à 09:02
Bonjour waea, Jean-Pierre,
Je pense comme Jean-Pierre, il s'agit peut-etre d'un probleme d'utilisation de la clé usb....Pour ce qui est de la procédure vba, je ne vois pas ce qui pourrait causer ce probleme, je l'ai testée plusieurs fois et je viens même d'essayer sur une autre machine (sous Vista), pas de probleme....De plus, j'utilise ce genre de procédures en vba/vbs depuis pas mal de temps et je n'ai jamais observé ce comportement...
As-tu fais un nouveau test depuis ? le probleme se reproduit-il à chaque utilisation de la macro ?
0
waea Messages postés 42 Date d'inscription lundi 18 janvier 2010 Statut Membre Dernière intervention 31 août 2015
1 févr. 2010 à 11:17
re bonjour,

tout d'abord j'ai recommencé et cela fonctionne : en fait j'ai une clé qui comporte un logiciel intégré nécessitant un mot de passe et un menu. j'avais cliquer pour fermer la clé via le programme intégré mais visiblement cela ne suffit pas !
il faut que je passe aussi par le menu d'éjection de windows !

par contre j'ai essayé avec une autre clé que j'ai nommé aussi PRI (pour privé) qui cette fois ci est en F: (alors que la clé précédente était en G:) ; le fichier s'enregistre également mais sur l'explorateur windows je n'ai pas la version de la copie ( date heure) de l'enregistrement ?
le fichier semble s'ouvrir également mais il serait pratique d'avoir ces infos!

pouvez vous m'expliquez SVP
merci d'avance

waea
0