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

Macros et VBA Excel Discussion :

vbscript dans vba ejecter les lecteurs amovibles


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Juin 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2017
    Messages : 3
    Par défaut vbscript dans vba ejecter les lecteurs amovibles
    Bonjour

    macro pour éjecter les lecteurs amovibles

    Sub Ejection_dde()

    On Error Resume Next

    ' Créer une instance du gestionnaire de disques logiques
    Set objWMIService = GetObject("winmgmts:\\.\root\cimv2")

    ' Parcourir les lettres de lecteur de E à M
    For i = Asc("E") To Asc("M")
    ' Convertir la lettre en majuscule
    strDriveLetter = UCase(Chr(i))

    ' Récupérer la liste des disques logiques pour la lettre de lecteur actuelle
    Set colDisks = objWMIService.ExecQuery("Select * from Win32_LogicalDisk where DriveType=2 and DeviceID='" & strDriveLetter & ":'")

    ' Si un disque amovible est présent pour cette lettre de lecteur, éjecter
    For Each objDisk In colDisks
    objDisk.Eject
    Next
    Next

    ' Libérer les ressources
    Set objWMIService = Nothing
    End Sub

    colDisks ne se charge pas !!


    Merci pour l'aide

  2. #2
    Expert confirmé
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    4 244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 4 244
    Par défaut
    Hello,
    voici un script qui éjecte les lecteurs USB amovibles montés :
    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
    Public Sub EjectUsb()
        Dim fso As Object, USBDrive As Object, myShell As Object, myDrive As Object
        Set fso = CreateObject("Scripting.FileSystemObject")
        Set myShell = CreateObject("Shell.Application")
        For Each myDrive In fso.Drives
            If myDrive.DriveType = 1 And myDrive.IsReady = True Then  'removeable and mounted
               ' If myDrive.VolumeName = strVolumeName Then
                    Set USBDrive = myShell.Namespace(17).Parsename(myDrive.Path)
                    If USBDrive.Type = "Lecteur USB" Then ' Check it really is a USB drive
                        USBDrive.InvokeVerb "Eject"
                    End If
                'End If
            End If
        Next
    End Sub
    Attention au test USBDrive.Type = "Lecteur USB" la chaîne à tester dépend de la langue utilisée par l'O.S exemple en anglais USB Drive


    Ami calmant, J.P

Discussions similaires

  1. [VBA] lister les fichiers contenus dans un .ZIP
    Par DJBORIE dans le forum VBA Access
    Réponses: 5
    Dernier message: 10/04/2007, 17h49
  2. Réponses: 9
    Dernier message: 19/02/2007, 20h33
  3. comment en VBA mettre les mots dans une cellule en oblique
    Par antoine.dandois dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 12/02/2007, 17h10
  4. [VBA] Gérer les erreurs d'insertion dans la base de données
    Par robert_trudel dans le forum VBA Access
    Réponses: 3
    Dernier message: 04/12/2006, 12h45
  5. [VBA]effacer les espaces à ralonge dans des cellules
    Par repié dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 26/01/2006, 11h00

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