[VBS]Récupérer le texte derrière un caractère
Résolu
bezourox
Messages postés
730
Date d'inscription
Statut
Membre
Dernière intervention
-
bezourox Messages postés 730 Date d'inscription Statut Membre Dernière intervention -
bezourox Messages postés 730 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Voilà je cherche à récupérer dans un fichier texte le contenu présent après une chaine de caractères définie.
Contenu de mon fichier.txt
Name="Toto"
Version="2.4.0"
Je souhaite que mon .vbs m'affiche :
Toto
2.4.0
J'ai trouvé la fonction qui permet de lire un fichier ligne par ligne, mais je ne vois pas quelle fonctionne permet de récupérer le contenu présent après une chaine de caractères passée en paramètre.
Faisable ?
Voilà je cherche à récupérer dans un fichier texte le contenu présent après une chaine de caractères définie.
Contenu de mon fichier.txt
Name="Toto"
Version="2.4.0"
Je souhaite que mon .vbs m'affiche :
Toto
2.4.0
J'ai trouvé la fonction qui permet de lire un fichier ligne par ligne, mais je ne vois pas quelle fonctionne permet de récupérer le contenu présent après une chaine de caractères passée en paramètre.
Faisable ?
A voir également:
- [VBS]Récupérer le texte derrière un caractère
- Caractère ascii - Guide
- Caractère spéciaux - Guide
- Comment recuperer un message supprimé sur whatsapp - Guide
- Caractere speciaux - Guide
- Vbs windows - Accueil - Optimisation
8 réponses
Bonjour Bezourox,
Je ne connais pas le VBS, mais pourquoi ne chercherais-tu pas la position du =, ou de ton premier et dernier " pour récupérer ce qu'il y a entre?
Je ne connais pas le VBS, mais pourquoi ne chercherais-tu pas la position du =, ou de ton premier et dernier " pour récupérer ce qu'il y a entre?
C'est exactement ce que je cherche à faire :-)
C'est juste que je ne trouve pas la fonction qui permet de faire ça, et idem pour moi je ne connais quasiment pas le vbs
C'est juste que je ne trouve pas la fonction qui permet de faire ça, et idem pour moi je ne connais quasiment pas le vbs
Si tu réussis à récupérer ligne par ligne les informations de ton fichier, tu peux peut-être utiliser la fonction InStr([start, ]string1, string2[, compare]):integer
Elle renvoie la position de ton string2 dans ton string1, en partant de la position start (le premier caractère est à 1), et compare permet de personnaliser la recherche selon la valeur :
-1 : Effectue une comparaison à l'aide de la valeur de l'instruction Option Compare.
0 :Effectue une comparaison binaire.
1 :Effectue une comparaison textuelle.
2 :Réservée à Microsoft Access. Effectue une comparaison basée sur les informations de votre base de données.
La position de ton premier " serait PosGuillemet = InStr(1,TaLigne,""",0)
Je te suggère de stocker ta ligne dans une variable temporaire car, une fois que tu as récupéré la position du premier guillemet, il te faut récupérer le second.
Pour faire cela, j'ai procédé de cette façon :
- Je crée une variable sTemp dans laquelle je mets le contenu de la ligne
- Je récupère la position du premier guillemet
- Je stocke dans la variable sTemp la chaine depuis la position du guillemet récupérée +1
- Je récupère à nouveau la position du premier guillemet rencontré (qui est en fait le deuxième du coup)
- Je copie dans une variable sResultat, la chaine partant de 1 jusqu'à la position du guillemet -1
Au besoin, j'ai fait un fichier Excel rempli de macros, si tu as besoin d'aides, je peux te donner quelques astuces...
Elle renvoie la position de ton string2 dans ton string1, en partant de la position start (le premier caractère est à 1), et compare permet de personnaliser la recherche selon la valeur :
-1 : Effectue une comparaison à l'aide de la valeur de l'instruction Option Compare.
0 :Effectue une comparaison binaire.
1 :Effectue une comparaison textuelle.
2 :Réservée à Microsoft Access. Effectue une comparaison basée sur les informations de votre base de données.
La position de ton premier " serait PosGuillemet = InStr(1,TaLigne,""",0)
Je te suggère de stocker ta ligne dans une variable temporaire car, une fois que tu as récupéré la position du premier guillemet, il te faut récupérer le second.
Pour faire cela, j'ai procédé de cette façon :
- Je crée une variable sTemp dans laquelle je mets le contenu de la ligne
- Je récupère la position du premier guillemet
- Je stocke dans la variable sTemp la chaine depuis la position du guillemet récupérée +1
- Je récupère à nouveau la position du premier guillemet rencontré (qui est en fait le deuxième du coup)
- Je copie dans une variable sResultat, la chaine partant de 1 jusqu'à la position du guillemet -1
Au besoin, j'ai fait un fichier Excel rempli de macros, si tu as besoin d'aides, je peux te donner quelques astuces...
Salut et merci pour les infos.
Je vais regarder ça cet aprem mais je pense avoir compris le concept.
Me reste plus qu'à retranscrire ça en vbs.
Snin pour ton fichier excel blindé de macros, oui je suis preneur :)
Je vais regarder ça cet aprem mais je pense avoir compris le concept.
Me reste plus qu'à retranscrire ça en vbs.
Snin pour ton fichier excel blindé de macros, oui je suis preneur :)
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Voilà le fichier en question. Il ne fonctionnera pas, à moins de faire quelques manip, dans ton environnement mais tu peux au moins voir les macros.
http://www.cijoint.fr/cjlink.php?file=cj201109/cija2uGxyZ.xlsm
Si vraiment tu veux voir comment fonctionne le fichier, dis-le moi ;)
http://www.cijoint.fr/cjlink.php?file=cj201109/cija2uGxyZ.xlsm
Si vraiment tu veux voir comment fonctionne le fichier, dis-le moi ;)
Bonjour,
Exemple Type :
À adapter selon vos besoin :-)
Cdt
Lupin
Exemple Type :
À adapter selon vos besoin :-)
'---------------------------------------------------------------------
' Fichier .vbs
Const ctePourLecture = 1
Const cteRapport = "Resultat.txt"
Dim objFSO, objFichier, varNomFic, Texte, Message
Dim Chaine, Position
Set objFSO = CreateObject("Scripting.FileSystemObject")
' Localisation du script et du fichier à lire
varNomFic = WScript.ScriptFullName
varNomFic = Left(varNomFic, InStrRev(varNomFic, "\"))
varNomFic = varNomFic & cteRapport
If ( objFSO.FileExists(varNomFic) ) Then
Set objFichier = objFSO.OpenTextFile(varNomFic, ctePourLecture)
While Not objFichier.AtEndOfStream
Texte = objFichier.ReadLine
Position = InStr(1, Texte, "=", 1)
Texte = Mid(Texte,(Position + 2))
Texte = Mid(Texte, 1, (Len(Texte) - 2))
Message = Message & vbCrLf & Texte
Wend
objFichier.Close
Set objFichier = Nothing
WScript.Echo Message
Else
WScript.Echo "Fichier absent"
End If
Set objFSO = Nothing
WScript.Quit(0)
'
'---------------------------------------------------------------------
Cdt
Lupin
re:
Tout d'abord :
Instruction [InStr]
https://www.microsoft.com/en-us/download/details.aspx?id=55984
Instruction [Mid]
https://docs.microsoft.com/fr-fr/dotnet/visual-basic/language-reference/statements/mid-statement
Le code avec des commentaires :
Cdt
Lupin
Tout d'abord :
Instruction [InStr]
https://www.microsoft.com/en-us/download/details.aspx?id=55984
Instruction [Mid]
https://docs.microsoft.com/fr-fr/dotnet/visual-basic/language-reference/statements/mid-statement
Le code avec des commentaires :
'---------------------------------------------------------------------
' Fichier .vbs
Const ctePourLecture = 1
' Nom du fichier à lire
Const cteRapport = "Resultat.txt"
Dim objFSO, objFichier, varNomFic, Texte, Message
Dim Chaine, Position
' Création d'on objet pour l'accès au système de fichier
Set objFSO = CreateObject("Scripting.FileSystemObject")
' Localisation du script et du fichier à lire
' Capture du nom complet du script
varNomFic = WScript.ScriptFullName
' Suppression du nom pur afin de conserver le chamin d'accès
varNomFic = Left(varNomFic, InStrRev(varNomFic, "\"))
' Ajout du nom du fichier à lire
varNomFic = varNomFic & cteRapport
' Si fichier existe
If ( objFSO.FileExists(varNomFic) ) Then
' Création d'un objet fichier pour accès au fichier, et ouverture
Set objFichier = objFSO.OpenTextFile(varNomFic, ctePourLecture)
' Tant que fichier n'est pas terminé
While Not objFichier.AtEndOfStream
' Lire une ligne
Texte = objFichier.ReadLine
' Recherche la position de caractère [=]
' InStr(1, Texte, "=", 1)
' 1 = À partir du premier caractère
' Texte = texte dans lequel la recherche s'effectue
' "=" = Caractère recherché
' 1 = Méthode de comparaison en texte
Position = InStr(1, Texte, "=", 1)
' Capture le texte 2 caractère plus loin
' donc après le [="]
Texte = Mid(Texte,(Position + 2))
' Enlève les 2 derniers caractères,
' le caractère de saut de ligne et les guillemets
Texte = Mid(Texte, 1, (Len(Texte) - 2))
' Ajoute le texte trouvé avec un saut de ligne [vbCrLf]
Message = Message & vbCrLf & Texte
Wend
' Ferme le fichier
objFichier.Close
' Libère l'objet Fichier
Set objFichier = Nothing
' Affiche à l'écran
WScript.Echo Message
Else
' Affiche à l'écran
WScript.Echo "Fichier absent"
End If
' Libère l'objet du système de fichier
Set objFSO = Nothing
' Quitte le script avec [0] comme paramètre
' pour signaler "Aucune erreur"
WScript.Quit(0)
'
'---------------------------------------------------------------------
Cdt
Lupin