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

Scripts/Batch Discussion :

Export des résultats vers un csv


Sujet :

Scripts/Batch

  1. #1
    Membre habitué
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Septembre 2015
    Messages : 8
    Par défaut Export des résultats vers un csv
    Bonjour,

    J'arrive à récupérer les compteurs d'imprimantes via ce script :

    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
    $SNMP = new-object -ComObject olePrn.OleSNMP
    
    #Copieur1
    $snmp.open("192.168.89.51","public",2,3000)
    $snmp.Get(".1.3.6.1.2.1.1.5.0")
    $snmp.Get(".1.3.6.1.2.1.25.3.2.1.3.1")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.102")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.106")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.109")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.112")
    $SNMP.Close()
    
    
    #Copieur2
    $snmp.open("192.168.89.53","public",2,3000)
    $snmp.Get(".1.3.6.1.2.1.1.5.0")
    $snmp.Get(".1.3.6.1.2.1.25.3.2.1.3.1")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.102")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.106")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.109")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.112")
    $SNMP.Close()

    Ce qui me donne ce résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Copieur1
    Canon iR-ADV C3325 12.07
    316058
    65377
    250679
    57
    Copieur2
    Canon iR-ADV C5240 48.04
    140831
    108954
    31870
    mais je ne sais pas comment exporter ces résultats vers un fichiers csv ou autre, pourriez vous m'aider ?

  2. #2
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Salut,
    cette fonction peut peut-être t'aider.

  3. #3
    Membre habitué
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Septembre 2015
    Messages : 8
    Par défaut
    Merci pour ton lien.

    J'ai modifié le titre car il y avait une petite erreur, c'est un export vers csv et non pst.

    J'ai testé un des exemples avec

    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
    $file ='c:\test.csv'
    @'
    $SNMP = new-object -ComObject olePrn.OleSNMP
    
    #Cop_GIE
    $snmp.open("192.168.89.51","public",2,3000)
    $snmp.Get(".1.3.6.1.2.1.1.5.0")
    $snmp.Get(".1.3.6.1.2.1.25.3.2.1.3.1")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.102")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.106")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.109")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.112")
    $SNMP.Close()
    
    
    #Cop_Het
    $snmp.open("192.168.89.53","public",2,3000)
    $snmp.Get(".1.3.6.1.2.1.1.5.0")
    $snmp.Get(".1.3.6.1.2.1.25.3.2.1.3.1")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.102")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.106")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.109")
    $snmp.Get(".1.3.6.1.4.1.1602.1.11.1.3.1.4.112")
    $SNMP.Close()
    '@ > $file
    mais malheureusement ca ne fait qu'importer le script brut dans un fichier et non le résultat.

  4. #4
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Une autre approche, a adapter à ton cas à l'aide du boucle repeat Until ( au moins une fois) :
    Code powershell : 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
     
    #les lignes concernant le résultat d'interrogation d'une imprimante doit être de 6
    $lines=@'
    Copieur1
    Canon iR-ADV C3325 12.07
    316058
    65377
    250679
    57
    Copieur2
    Canon iR-ADV C5240 48.04
    140831
    108954
    31870
    xx #manque dans ton exemple
    '@
     
    #transforme en tableau de string la chaine $Lines
    #la here string n'utilise pas CRLF mais LF uniquement, c'est Powershell... 
    $tab=$lines -split "\`n"
     
     #construit rapido un objet personnalisé
    $o=1|select Nom,label,c1,c2,c3,c4
     
     #affecte les 6 première lignes de Tab dans les propriétés de l'objet et le reste dans $tab (nouvelle affectation)
    $o.Nom,$o.label,$o.c1,$o.c2,$o.c3,$o.c4,$tab=$tab
     #contrôle
    $o
    $tab
    $nul -eq $tab #non, pas encore
     
    #on refait la même chose tant que $tab n'est pas à $null ( donc tant qu'il n'est pas vide)
    $o=1|select Nom,label,c1,c2,c3,c4
    $o.Nom,$o.label,$o.c1,$o.c2,$o.c3,$o.c4,$tab=$tab
    $o
    $tab
    $nul -eq $tab #Oui il est vide
    La fonction proposée précédement utilise des regex qui ne sont pas nécessaires dans ton cas. On reprend le principe du découpage mais en plus simple ou presque

  5. #5
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Une ébauche :
    Code Powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $tab=$lines -split "\`n"
    ($tab.count % 6) -eq 0 #true ok multiple de 6
    $Objects=Do {
     $O=[PScustomObject]@{Nom='';Label='';Property1='';Property2='';Property3='';Property4=''}
     $o.Nom,$o.Label,$O.Property1,$o.Property2,$o.Property3,$o.Property4,$tab=$tab
     $o
    } until ($nul -eq $tab)
    $objects.Count
    $objects
    Résultat:

    Nom : Copieur1
    Label : Canon iR-ADV C3325 12.07
    Property1 : 316058
    Property2 : 65377
    Property3 : 250679
    Property4 : 57

    Nom : Copieur2
    Label : Canon iR-ADV C5240 48.04
    Property1 : 140831
    Property2 : 108954
    Property3 : 31870
    Property4 : xx #manque dans ton exemple

Discussions similaires

  1. Réponses: 5
    Dernier message: 13/05/2018, 16h43
  2. Réponses: 4
    Dernier message: 06/03/2017, 16h27
  3. [PowerShell] Exporter des résultats Cplex vers Excel via Powershell
    Par Tfo89 dans le forum Scripts/Batch
    Réponses: 0
    Dernier message: 10/05/2014, 18h07
  4. [Access 2002] Exporter des données vers une base Access 2.0
    Par SamLeChiseuji dans le forum Access
    Réponses: 27
    Dernier message: 01/06/2006, 11h41
  5. exporter des données vers EXCEL!
    Par JauB dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 25/11/2005, 15h13

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