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 :

Recherche de chaine de caracteres entre deux "variables"


Sujet :

VBScript

  1. #1
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut Recherche de chaine de caracteres entre deux "variables"
    Bonjour, a tous.

    Je precise avant de commencer que je suis un debutant en vbs et que sa fait 2 jours que je cherche des info sur InStr.

    J'ai un fichier Log de plus de 4000 lignes, je doit y recuperer differentes informations qui sont sous la forme suivante :


    <![LOG[Property OSDAdapter0MacAddress is now = XX:XX:XX:XX:XX:XX]LOG]!><time="10:43:02.000+000" date="01-21-2015" component="Wizard" context="" type="1" thread="" file="Wizard">
    <![LOG[Property OSDAdapter0IPAddressList is now = XX.XX.XX.XX]LOG]!><time="10:43:02.000+000" date="01-21-2015" component="Wizard" context="" type="1" thread="" file="Wizard">
    <![LOG[Property OSDAdapter0SubnetMask is now = XX.XX.XX.XX]LOG]!><time="10:43:02.000+000" date="01-21-2015" component="Wizard" context="" type="1" thread="" file="Wizard">
    <![LOG[Property OSDAdapter0Gateways is now = XX.XX.XX.XX]LOG]!><time="10:43:02.000+000" date="01-21-2015" component="Wizard" context="" type="1" thread="" file="Wizard">
    <


    Les informations que je doit récupérer sont par exemple l'adresse MAC et les IP, masque ect .. Mon idée est de trouver le champ :
    <![LOG[Property OSDAdapter0IPAddressList is now =
    Dans le fichier, et de lire jusqu'au prochain :
    ]LOG
    Puis placer ce qu'il trouve au milieu dans une variable .. tout simplement .. et je mouline depuis 2 jours sans resultats.

    Je tien a preciser que je suis debutant en vbs, mais pas la peine de me donner le lien msdn de InStr je l'ai trouvé ..^^

    Si quelqu'un veut bien me venir en aide, se sera avec plaisir !

  2. #2
    Membre chevronné

    Homme Profil pro
    développeur
    Inscrit en
    Octobre 2013
    Messages
    1 576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : développeur

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 576
    Points : 1 989
    Points
    1 989
    Par défaut
    Bonjour, peut-être ce lien là alors http://drq.developpez.com/vb/tutoriels/String/

  3. #3
    Modérateur
    Avatar de l_autodidacte
    Homme Profil pro
    Retraité : Directeur de lycée/Professeur de sciences physiques
    Inscrit en
    Juillet 2009
    Messages
    2 415
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Retraité : Directeur de lycée/Professeur de sciences physiques
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2009
    Messages : 2 415
    Points : 5 805
    Points
    5 805
    Par défaut
    Bonjour et Bienvenu sur DVP

    Parmi nous, il y a ceux qui ne lisent pas correctement ou peu les remarques des intervenants !!
    Pour un début et selon ton approche qui peut être une solution, il y a ce petit bout de
    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
    Option Explicit
    Const ForReading = 1
    Const ForWriting = 2
    Dim fso, fichLog, Ret, tmp, FichResult
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set fichLog = fso.OpenTextFile("Logfile.log", ForReading, False)
    Ret = ""
    Set FichResult = fso.OpenTextFile("Resultat.log", ForWriting, True)
    Do While Not fichLog.AtEndOfStream
       tmp = fichLog.ReadLine
       If tmp <> "" Then 
          MsgBox EntreLimites(tmp)
          FichResult.WriteLine EntreLimites(tmp) ' On consigne le résultat dans fichier !
       End If
    Loop
    FichLog.Close
    FichResult.Close
    ' =========================
    Function EntreLimites(strIn)
        Dim temp, I, retVal, PosDebut, PosFin
        PosDebut = InStr(1, strIn, "<![LOG", vbTextCompare) ' On peut se passer de cette instruction et 
          '  la remplacer par 1 dans la boucle For ...To
          '  puisqu'on est au début de la ligne(sauf mention contraire)
        PosFin = InStr(1, strIn, "LOG]!>", vbTextCompare)
        temp = ""
        For I = PosDebut To PosFin + 5       ' +5 sinon on s'arrêtera à la lettre L de "LOG]!>"
           temp = temp & Mid(strIn, I, 1)
        Next
        EntreLimites = temp
    End Function
    Ce code peut être amélioré pour répondre à ton besoin.
    Ne pas oublier le tag si satisfait.
    Voter pour toute réponse satisfaisante avec pour encourager les intervenants.
    Balises CODE indispensables. Regardez ICI
    Toujours utiliser la clause Option Explicit(VBx, VBS ou VBA) et Ne jamais typer variables et/ou fonctions en VBS.
    Vous pouvez consulter mes contributions
    Ne pas oublier de consulter les différentes FAQs et les Cours/Tutoriels VB6/VBScript
    Ne pas oublier L'Aide VBScript et MSDN VB6 Fr

  4. #4
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Bonjour, et merci pour l'acceuil et ta réponse l_autodidacte.

    Je suis desolé je voit bien que je script est commenté, mais je ne sait, ou comprend pas, comment l'adapter,afin d'y integrer les éléments pour la recherche ..
    Le fichier Logfile.log est bien le fichier a etudier, np, le Resultat.log parle de lui même, mais apres .. je ne voit pas trop comment m'en sortir ..

  5. #5
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Ok, j'ai a peut pres compris le fonctionnement du script, sauf que se n'est pas tout a fait se que je cherche a faire et je ne parvient pas a arriver a mes fin ..

    le resultat actuel est :

    <![LOG[Property OSDAdapter0MacAddress is now = XX:XX:XX:XX:XX:XX]LOG]!>
    <![LOG[Property OSDAdapter0IPAddressList is now = XX.XX.XX.XX]LOG]!>
    <![LOG[Property OSDAdapter0SubnetMask is now = XX.XX.XX.XX]LOG]!>
    <![LOG[Property OSDAdapter0Gateways is now = XX.XX.XX.XX]LOG]!>


    Moi je cherche juste a touver la ligne :

    <![LOG[Property OSDAdapter0IPAddressList is now =

    Et à recuperer le texte :

    XX.XX.XX.XX

    Jusqu'au prochain :

    ]LOG]!>

  6. #6
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Malgrés une petite modification, je pensai que sa allais être bon, mais j'ai une erreur sur la ligne 27 - 8, par rapport a Mid ..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Function EntreLimites(strIn)
        Dim temp, I, retVal, PosDebut, PosFin
        PosDebut = InStr(1, strIn, "<![LOG[Property OSDAdapter0IPAddressList is now =", vbTextCompare) ' On peut se passer de cette instruction et 
          '  la remplacer par 1 dans la boucle For ...To
          '  puisqu'on est au début de la ligne(sauf mention contraire)
        PosFin = InStr(1, strIn, "LOG]!>", vbTextCompare)
        temp = ""
        For I = PosDebut To PosFin + 5       ' +5 sinon on s'arrêtera à la lettre L de "LOG]!>"
           temp = temp & Mid(strIn, I, 1)
        Next
        EntreLimites = temp
    End Function
    Une idée ou un conseil ?

  7. #7
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Bonjour,

    Si ça peut t'aider ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Chaine = "<![LOG[Property OSDAdapter0MacAddress is now = XX:XX:XX:XX:XX:XX]LOG]!>"
    Deb = InStr(Chaine, "is now = ") + 9
    Chaine = Mid(Chaine, Deb)
    Fin = InStr(Chaine, "]LOG") - 1

  8. #8
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Bonjour, et merci pour ton aide.

    Oui cela peut m'aider, sauf que je tente de recuperer du texte, dont le format peut varier, sur un ligne qui commence toujour de la meme facon et termine toujours de la meme facon :

    Cesi_est_mon_debut_de_ligne:texte_variable_a_recuperer:fin_de_la_ligne

    Je voudrais pouvoir donner au script " de_ligne: " et " :fin_de " et que lui me sorte "texte_variable_a_recuperer"

    Je ne sais pas si je m'explique bien ou pas...

  9. #9
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Re,

    Dans le code que je t'ai donné, si tu ajoutes cette instruction à la fin, le résultat correspond bien à l'adresse, non ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Chaine = "<![LOG[Property OSDAdapter0MacAddress is now = XX:XX:XX:XX:XX:XX]LOG]!>"
    Deb = InStr(Chaine, "is now = ") + 9
    Chaine = Mid(Chaine, Deb)
    Fin = InStr(Chaine, "]LOG") - 1
    MsgBox Mid(Chaine, 1, Fin)

  10. #10
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Oui le code renvois bien XX:XX:XX:XX:XX:XX

    J'explique differement ,j'ai un fichier de 5000 ligne toute structuré de la même maniere, exemple de ligne :

    "
    TEXTE1 INCONUE2 TEXTE3
    TEXTE4 INCONUE5 TEXTE6
    TEXTE7 INCONUE8 TEXTE9
    "

    Un script cherche une seule valeur, donc une ligne parmis es 5000.
    On donne au script le TEXTE1 et le TEXTE3 pour en sortir la valeur INCONUE2 dont je ne connait pas la structure, date, texte, caracteres speciaux ...

    Un colegue m'a conseillé e trouver la position de TEXTE1, la position de TEXTE3 soustraire le resultat et en deduire la position et la taille de INCONUE2 pour la récuperer ...

    Sa commence a chauffer de mon coté, j'ai des script de partout sur mon ecran et rien qui marche ^^.

  11. #11
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Citation Envoyé par frederic.64400 Voir le message
    Un script cherche une seule valeur, donc une ligne parmis es 5000.
    Tu peux préciser le sens de cette ligne, stp ?

  12. #12
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Citation Envoyé par pc75 Voir le message
    Tu peux préciser le sens de cette ligne, stp ?

    Sur :


    "
    <![LOG[Property OSDAdapter0SubnetMask is now = INCONUE]LOG]!><time="10:43:02.000+000" date="01-21-2015" component="Wizard" context="" type="1" thread="" file="Wizard">
    "

    Je ne cherche a avoir que "INCONUE", je peut donner au script sa :

    "
    <![LOG[Property OSDAdapter0SubnetMask is now =
    "

    Et sa :

    "
    ]LOG]!
    "

    Bien entendu, il faut au prealable que je trouve la ligne..

  13. #13
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Regarde ce code :

    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
     
    Option Explicit
    Const ForReading = 1
    Const ForWriting = 2
    Dim fso, fichLog, Ret, tmp, FichResult
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set fichLog = fso.OpenTextFile("Logfile.log", ForReading, False)
    Ret = ""
    Set FichResult = fso.OpenTextFile("Resultat.log", ForWriting, True)
    Do While Not fichLog.AtEndOfStream
       tmp = fichLog.ReadLine
       If tmp <> "" Then 
          MsgBox EntreLimites(tmp)
          FichResult.WriteLine EntreLimites(tmp) ' On consigne le résultat dans fichier !
       End If
    Loop
    FichLog.Close
    FichResult.Close
    ' =========================
    Function EntreLimites(strIn)
       Deb = InStr(strIn, "is now = ") + 9
       strIn = Mid(strIn, Deb)
       Fin = InStr(strIn, "]LOG") - 1
       EntreLimites = Mid(strIn, 1, Fin)
    End Function
    La ligne 21 recherche la position de la chaine "is now = " + 9
    La ligne 22 ne conserve que la partie de la chaine après "is now = "
    La ligne 23 recherche la position de la chaine "]LOG" - 1
    La ligne 24 retourne la chaine que tu veux extraire, non ?

  14. #14
    Modérateur
    Avatar de l_autodidacte
    Homme Profil pro
    Retraité : Directeur de lycée/Professeur de sciences physiques
    Inscrit en
    Juillet 2009
    Messages
    2 415
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Retraité : Directeur de lycée/Professeur de sciences physiques
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2009
    Messages : 2 415
    Points : 5 805
    Points
    5 805
    Par défaut
    Dans le cas où tu aurais besoin du nom du périphérique(ou son nom descriptif), tu peux utiliser ce
    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
     
    Option Explicit
    Const ForReading = 1
    Const ForWriting = 2
    Dim fso, fichLog, Ret, tmp, FichResult, Deb, Fin
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set fichLog = fso.OpenTextFile("Logfile.log", ForReading, False)
    Ret = ""
    Set FichResult = fso.OpenTextFile("Resultat.log", ForWriting, True)
    Do While Not fichLog.AtEndOfStream
       tmp = fichLog.ReadLine
       If tmp <> "" Then 
        '  MsgBox EntreLimites(tmp)
          FichResult.WriteLine AdapterInfos(tmp) & " = " & EntreLimites(tmp) ' On consigne le résultat dans un fichier !
       End If
    Loop
    FichLog.Close
    FichResult.Close
    ' =========================
    Function EntreLimites(strIn)
       Deb = InStr(strIn, "is now = ") + 9
       strIn = Mid(strIn, Deb)
       Fin = InStr(strIn, "]LOG") - 1
       EntreLimites = Mid(strIn, 1, Fin)
    End Function
    '==========================
    Function AdapterInfos(strAdapt)
        Dim Debut, Fin
            Debut = InStr(1, strAdapt, "OSDAdapter", 1)
            Fin = InStr(1, strAdapt, "is now", 1) - 2
            AdapterInfos = Mid(strAdapt, Debut, Fin - Debut + 1)
    End Function
    Ne pas oublier le tag si satisfait.
    Voter pour toute réponse satisfaisante avec pour encourager les intervenants.
    Balises CODE indispensables. Regardez ICI
    Toujours utiliser la clause Option Explicit(VBx, VBS ou VBA) et Ne jamais typer variables et/ou fonctions en VBS.
    Vous pouvez consulter mes contributions
    Ne pas oublier de consulter les différentes FAQs et les Cours/Tutoriels VB6/VBScript
    Ne pas oublier L'Aide VBScript et MSDN VB6 Fr

  15. #15
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2015
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2015
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Merci a tous pour votre aide !!

    Voila se que j'ai fait :

    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
    Option Explicit
    Const ForReading = 1
    Const ForWriting = 2 'Const ForWriting = 8 Si je veut ajouter du texte sans ecraser le fichier
    Dim fso, fichLog, tmp, FichResult
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set fichLog = fso.OpenTextFile("Logfile.log", ForReading, False)
    Set FichResult = fso.OpenTextFile("Resultat.log", ForWriting, True)
       tmp = fichLog.ReadAll
       If tmp <> "" Then 
    		FichResult.WriteLine EntreLimites(tmp) ' On consigne le résultat dans fichier !
       End If
    FichLog.Close
    FichResult.Close
    ' =========================
    Function EntreLimites(strIn)
        Dim temp, PosDebut, PosFin, I
        PosDebut = InStr(1, strIn, "<![LOG[Property OSDAdapter0MacAddress is now =", 0)+46
    	PosFin = InStr(PosDebut, strIn, "]LOG]!><time",0)
    	temp = ""
    	I = (PosFin - PosDebut)
        temp = temp & Mid(strIn,PosDebut,I)
    	EntreLimites = temp
    End Function

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 20/08/2012, 17h41
  2. Remplacer une chaine de caractere entre deux balise
    Par xyrox dans le forum Langage
    Réponses: 2
    Dernier message: 28/12/2010, 14h11
  3. Réponses: 9
    Dernier message: 31/05/2005, 14h34

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