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 :

Tabulation dans un fichier texte


Sujet :

VBScript

  1. #1
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation dans un fichier texte
    Bonjour à tous,

    Suite à mon post d'hier (réglé, merci à CED 600 pour le lien), je récupère don un fichier texte avec tous les softs installés, par ex:

    Mozilla Firefox (2.0.0.11) Version: 2.0.0.11 (fr)
    Mozilla Thunderbird (2.0.0.9) Version: 2.0.0.9 (fr)
    Adobe Reader 8.1.1 - Français Version: 8.1.1

    je voudrais savoir si il est possible de tabuler le fichier afin d'obtenir:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Mozilla Firefox (2.0.0.11)             Version: 2.0.0.11 (fr)
    Mozilla Thunderbird (2.0.0.9)          Version: 2.0.0.9 (fr)
    Adobe Reader 8.1.1 - Français          Version: 8.1.1
    j'ai essayé avec des vbTab, sans succès.

    Merci par avance
    Philippe

  2. #2
    Expert confirmé
    Avatar de ced600
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2006
    Messages
    3 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2006
    Messages : 3 364
    Points : 4 061
    Points
    4 061
    Par défaut
    Mozilla Firefox (2.0.0.11) Version: 2.0.0.11 (fr)
    Mozilla Thunderbird (2.0.0.9) Version: 2.0.0.9 (fr)
    Adobe Reader 8.1.1 - Français Version: 8.1.1

    je voudrais savoir si il est possible de tabuler le fichier afin d'obtenir:

    Mozilla Firefox (2.0.0.11) Version: 2.0.0.11 (fr)
    Mozilla Thunderbird (2.0.0.9) Version: 2.0.0.9 (fr)
    Adobe Reader 8.1.1 - Français Version: 8.1.1
    Aucune différence. Certainement parce que les tabulations sont supprimé du texte d'un post.

    Met des - à la place des espaces pour montrer comment tu veux organiser ta présentation.
    Pourquoi faire compliqué lorsque l'on peut faire encore plus compliqué.

  3. #3
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation dans un fichier texte
    Mozilla Firefox (2.0.0.11) Version: 2.0.0.11 (fr)
    Mozilla Thunderbird (2.0.0.9) Version: 2.0.0.9 (fr)
    Adobe Reader 8.1.1 - Français Version: 8.1.1

    En fait, j'aimerai obtenir des zones alignées, par exemple réserver xx caractères pour le nom du soft (qques soit la longueur de la chaine), et yy caractères pour la version

    Philippe

  4. #4
    Expert éminent
    Avatar de ThierryAIM
    Homme Profil pro
    Inscrit en
    Septembre 2002
    Messages
    3 673
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2002
    Messages : 3 673
    Points : 8 524
    Points
    8 524
    Par défaut
    Citation Envoyé par ced600 Voir le message
    Aucune différence. Certainement parce que les tabulations sont supprimé du texte d'un post.
    dans ce cas, mieux vaut utiliser les balises Code qui utilisent une police non proprtionnelle.
    J'ai modifié le 1er post de phberanger (sous réserve que j'ai bien compris ce qu'il veut obtenir )
    Vous vous posez une question, la réponse est peut-être ici :
    Toutes les FAQs VB
    Les Cours et Tutoriels VB6/VBScript
    Les Sources VB6


    Je ne réponds pas aux questions techniques par MP. Utilisez les forums. Merci de votre compréhension

  5. #5
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation dans un fichier texte
    J'ai modifié le 1er post de phberanger (sous réserve que j'ai bien compris ce qu'il veut obtenir )

    Pas de problème, c'est bien ce que j'aimerai obtenir. Par contre "balise code", je ne connais pas, pas vu de trace dans Script56.CHM

    Encore merci

  6. #6
    Expert éminent
    Avatar de ThierryAIM
    Homme Profil pro
    Inscrit en
    Septembre 2002
    Messages
    3 673
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2002
    Messages : 3 673
    Points : 8 524
    Points
    8 524
    Par défaut
    les balises Code, c'est pour la présentation de ton post (fais un edit sur ton premier post )

    Citation Envoyé par phberanger Voir le message
    j'ai essayé avec des vbTab, sans succès.
    on peut voir le bout de script ?
    Vous vous posez une question, la réponse est peut-être ici :
    Toutes les FAQs VB
    Les Cours et Tutoriels VB6/VBScript
    Les Sources VB6


    Je ne réponds pas aux questions techniques par MP. Utilisez les forums. Merci de votre compréhension

  7. #7
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation dans un fichier texte
    donc le script: j'ouvre mon fichier texte, qui provient d'un autre script qui récupère les entrées uninstall dans la bdr ), et je trie le fichier alphabétiquement (d'après un script récupéré sur le web:

    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    'Tri du fichier par ordre alphabétique
    Const adVarChar = 200
    Const MaxCharacters = 255
    Const ForReading = 1
    Const ForWriting = 2
     
    Set DataList = CreateObject("ADOR.Recordset")
    DataList.Fields.Append "SoftWare", adVarChar, MaxCharacters
    DataList.Open
     
    Set objFile = objFSO.OpenTextFile("C:\Temp\Soft\SoftWare.txt", ForReading)
     
    Do Until objFile.AtEndOfStream
        strLine = objFile.ReadLine
        DataList.AddNew
        DataList("SoftWare") = strLine
        DataList.Update
    Loop
     
    objFile.Close
     
    DataList.Sort = "SoftWare"
     
    DataList.MoveFirst
    Do Until DataList.EOF
        strText = strText & DataList.Fields.Item("SoftWare") & vbCrLf
        DataList.MoveNext
    Loop
     
    Set objFile = objFSO.OpenTextFile("C:\Temp\Soft\SoftWare.txt", ForWriting)
     
    objFile.WriteLine strText
    objFile.Close
     
     
    et j'obtiens, par ex
     
    Adobe Flash Player 9 ActiveX	Version: 9
    Adobe Reader 8.1.1 - Français	Version: 8.1.1
    Adobe Reader Japanese Fonts	Version: 7.00.000
    Apple Software Update	Version: 2.0.0.21
    Archiveur WinRAR	Version: 
    Broadcom Advanced Control Suite 2	Version: 7.58.01
    Broadcom Advanced Control Suite 2	Version: 7.58.01
    Broadcom ASF Management Applications	Version: 5.08.01
    Broadcom ASF Management Applications	Version: 5.08.01
    donc rien n'est aligné...

    Merci

  8. #8
    Expert confirmé
    Avatar de ced600
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2006
    Messages
    3 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2006
    Messages : 3 364
    Points : 4 061
    Points
    4 061
    Par défaut
    Edit ton poste,

    Sélectionne tout le code et Appui avec la souris sur #, et envois la réponse


    Edit : [Fait] Thierry
    Pourquoi faire compliqué lorsque l'on peut faire encore plus compliqué.

  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
    Bonjour,

    Une question :

    Le contenu de DataList.Fields.Item("SoftWare") contient le nom du soft et la version ?

  10. #10
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation
    Tout a fait, j'ai rajouté un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WScript.Echo DataList.Fields.Item("SoftWare")
    et j'ai bien

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Adobe Flash Player 9 ActiveX	Version: 9
    Adobe Reader 8.1.1 - Français	Version: 8.1.1
    Adobe Reader Japanese Fonts	Version: 7.00.000
    Apple Software Update	Version: 2.0.0.21

    etc
    .
    .

  11. #11
    Expert confirmé
    Avatar de ced600
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2006
    Messages
    3 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2006
    Messages : 3 364
    Points : 4 061
    Points
    4 061
    Par défaut
    Je pense que oui.

    Utilise split sur la variable strText pour obtenir un tableau ou chaque ligne du tableau représente une ligne du fichier.

    Pour chaque ligne repère l'indice de l'espace avant version et remplace le par un nombre d'espace qui correspond au nombre de caractère de la partie gauche de la plus longue ligne + 10
    SI je suis ton exemple c'est :
    Taille de cela "Broadcom ASF Management Applications" + 10

    Copie chaque ligne de ton tableau dans le fichier et c'est bon

    Edit : Mais n'écrivez pas plus vite que moi
    Pourquoi faire compliqué lorsque l'on peut faire encore plus compliqué.

  12. #12
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation dans un fichier texte
    je fais ça de suite,

    merci

  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
    Re,

    Alors, une piste :

    Tu récupères la position du mot "version" avec la fonction Instr()

    ensuite, tu extraits la nom du logiciel (NomSoft) et sa version (VersionSoft) avec la fonction Mid() en te servant de la position du mot version.

    et pour aligner, tu peux faire un truc comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    StrLigne = space(50 - len(trim(NomSoft))) & NomSoft & space(50 - len(trim(VersionSoft))) & VersionSoft
    Tu dis ?

  14. #14
    Expert confirmé
    Avatar de ced600
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2006
    Messages
    3 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2006
    Messages : 3 364
    Points : 4 061
    Points
    4 061
    Par défaut
    Plutot que 50 ce serait mieux de prendre la taille de la plus longue ligne, non ?
    Pourquoi faire compliqué lorsque l'on peut faire encore plus compliqué.

  15. #15
    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 ced600 Voir le message
    Plutot que 50 ce serait mieux de prendre la taille de la plus longue ligne, non ?
    Bien sur, c'était juste pour l'exemple.

  16. #16
    Membre à l'essai
    Inscrit en
    Novembre 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 32
    Points : 15
    Points
    15
    Par défaut Tabulation dans un fichier texte
    Qui va piano.... je suis en train de voir la commande intSTR pour récupérer la position de Version, j'aurai peut-être terminé lundi

  17. #17
    Expert éminent
    Avatar de ThierryAIM
    Homme Profil pro
    Inscrit en
    Septembre 2002
    Messages
    3 673
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2002
    Messages : 3 673
    Points : 8 524
    Points
    8 524
    Par défaut
    Citation Envoyé par ced600 Voir le message
    Plutot que 50 ce serait mieux de prendre la taille de la plus longue ligne, non ?
    oui, mais il faut la chercher avant de faire le traitement de mise en forme

    Sinon, un Split sur "Version", c'est plus simple que de rechercher le nom, et le reste
    il suffira de rajouter "Version" dans la compo de la ligne final
    un petit exemple à mon idée (à adapter) :
    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
    Const ForReading = 1, ForWriting = 2 
    Dim oFso, f1, f2
    Dim ts, nl
     
      Set oFso = CreateObject("Scripting.FileSystemObject")
      Set f1 = oFso.OpenTextFile("c:\test1.txt", ForReading)
      ts = f1.ReadAll '-- Lit la totalité du fichier
      nl = f1.Line    '-- Récupère le nombre de lignes
     
    Dim i, lgn, lenlgn, sline
      ' Recherche la ligne la plus longue
      Set f1 = oFso.OpenTextFile("c:\test1.txt", ForReading)
      For i = 1 to nl   '-- l'index de la première ligne = 1
         lgn = f1.ReadLine
         sline = Split (lgn, "Version", -1, 1)
         if len(sline(0))> lenlgn then lenlgn = len(sline(0))
      Next
      f1.Close
     
      ' Effectue la mise en forme
      Set f1 = oFso.OpenTextFile("c:\test1.txt", ForReading)
      Set f2 = oFso.OpenTextFile("c:\test2.txt", ForWriting)
      For i = 1 to nl   '-- l'index de la première ligne = 1
         lgn = f1.ReadLine
         sline = Split (lgn, "Version", -1, 1)
         f2.Write (sline(0) & space(lenlgn + 2 - len(sline(0))) & "Version" & sline(1) & vbCrLf)
      Next
      f1.Close
      f2.Close
      Set oFso = Nothing
    Vous vous posez une question, la réponse est peut-être ici :
    Toutes les FAQs VB
    Les Cours et Tutoriels VB6/VBScript
    Les Sources VB6


    Je ne réponds pas aux questions techniques par MP. Utilisez les forums. Merci de votre compréhension

  18. #18
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 535
    Points
    5 535
    Par défaut
    Bonjour,

    LSet existe en VBS (Rset également, d'ailleurs, bien qu'ici LSet soit suffisant).

  19. #19
    Expert confirmé
    Avatar de ced600
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2006
    Messages
    3 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2006
    Messages : 3 364
    Points : 4 061
    Points
    4 061
    Par défaut
    J'ai oublié ce que faisait ces deux fonctions, des alignement en début et fin de string ?
    Pourquoi faire compliqué lorsque l'on peut faire encore plus compliqué.

  20. #20
    Expert éminent
    Avatar de ThierryAIM
    Homme Profil pro
    Inscrit en
    Septembre 2002
    Messages
    3 673
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2002
    Messages : 3 673
    Points : 8 524
    Points
    8 524
    Par défaut
    Citation Envoyé par ucfoutu Voir le message
    LSet existe en VBS (Rset également, d'ailleurs, bien qu'ici LSet soit suffisant).
    Au lieu de pister mes posts et de nous prendre pour des buses, fais-moi voir un exemple qui marche en VBS
    Vous vous posez une question, la réponse est peut-être ici :
    Toutes les FAQs VB
    Les Cours et Tutoriels VB6/VBScript
    Les Sources VB6


    Je ne réponds pas aux questions techniques par MP. Utilisez les forums. Merci de votre compréhension

Discussions similaires

  1. [IML] Tabulation dans un fichier texte
    Par stefsas dans le forum SAS IML
    Réponses: 5
    Dernier message: 06/05/2008, 14h13
  2. Detecter les tabulations dans un fichier texte
    Par Benji01 dans le forum VBA Access
    Réponses: 0
    Dernier message: 18/04/2008, 16h23
  3. detécter une tabulation dans un fichier texte
    Par john123 dans le forum Langage
    Réponses: 3
    Dernier message: 17/08/2007, 11h14
  4. [TP7] Insérer dans une tabulation dans un fichier texte
    Par astyan dans le forum Turbo Pascal
    Réponses: 2
    Dernier message: 05/08/2006, 14h58
  5. [VBA-E]Remplacement virgules par tabulation dans un fichier texte
    Par Mlezen dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 03/05/2006, 14h03

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