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 :

Découper un fichier texte [PowerShell]


Sujet :

Scripts/Batch

  1. #1
    Membre confirmé
    Profil pro
    Pôle Etude et Automatisation
    Inscrit en
    Avril 2007
    Messages
    166
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Pôle Etude et Automatisation
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Avril 2007
    Messages : 166
    Par défaut Découper un fichier texte
    Bonsoir,

    Comment récupérer un nombre de lignes (60 dans mon cas) pour les recopier dans un nouveau fichier après avoir trouvé le numéro ligne contenant un terme? Le script ci dessous ne recopie que la ligne contenant le texte recherché.

    Exemple Dans un fichier de 200 lignes, le terme recherché se trouve en 15eme ligne, je veux récupérer les lignes de 15 à 75.

    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
    Clear-Host
    $varCheminRepertoireScript = [System.IO.Path]::GetDirectoryName($MyInvocation.MyCommand.Definition) #On récupére le chemin du répertoire contenant ce script
    $currentScriptName = $MyInvocation.MyCommand.Name #Récupération du nom du script en cours
    $currentScriptName = $currentScriptName.substring(0,$($currentScriptName.lastindexofany(".")))
     
     
    $MonFolder = Get-ChildItem -Path $varCheminRepertoireScript -File  | Where-Object {$_.Name -match '.txt$'} #On récupére la liste des fichiers en .txt de ce répertoire
     
     foreach ($MyFile in $MonFolder) 
     { 
     
      #Création du fichier contenant le résultat
      $EmplacementFichierAvecLeResultat = "$varCheminRepertoireScript\aa\$($MyFile)_Resultat.txt"
      $MonFichierAvecLeResultat = New-Item -type file $EmplacementFichierAvecLeResultat -Force
     
      #Ouverture du fichier à analyser
      $NomFichieraLire = $MyFile
      $EmplacementFichier = [string]
      $EmplacementFichier = "$varCheminRepertoireScript\$NomFichieraLire"
      $MonFichier = get-content $EmplacementFichier
     
      $NumeroDeLine = 0
      foreach ($UneLigne in $MonFichier){
          $NumeroDeLine++
          if ($UneLigne -match 'RAR451' -eq $true) { #Lignes qui contiennent le mot RAR451
              $MyLine = "Ligne $($NumeroDeLine) : $($UneLigne)"
              Write-host $MyLine
              add-content $MonFichierAvecLeResultat $MyLine
          }
      }
     
     }

    Merci

  2. #2
    Membre confirmé
    Profil pro
    Pôle Etude et Automatisation
    Inscrit en
    Avril 2007
    Messages
    166
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Pôle Etude et Automatisation
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Avril 2007
    Messages : 166
    Par défaut
    Solution

    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
    38
    Clear-Host
    $varCheminRepertoireScript = [System.IO.Path]::GetDirectoryName($MyInvocation.MyCommand.Definition) #On récupére le chemin du répertoire contenant ce script
    $currentScriptName = $MyInvocation.MyCommand.Name #Récupération du nom du script en cours
    $currentScriptName = $currentScriptName.substring(0,$($currentScriptName.lastindexofany(".")))
     
     
    $MonFolder = Get-ChildItem -Path $varCheminRepertoireScript -File  | Where-Object {$_.Name -match '.txt$'} #On récupére la liste des fichiers en .txt de ce répertoire
     
     foreach ($MyFile in $MonFolder) 
     { 
     
      #Création du fichier contenant le résultat
      $EmplacementFichierAvecLeResultat = "$varCheminRepertoireScript\aa\$($MyFile)_Resultat.txt"
      $MonFichierAvecLeResultat = New-Item -type file $EmplacementFichierAvecLeResultat -Force
     
      #Ouverture du fichier à analyser
      $NomFichieraLire = $MyFile
      $EmplacementFichier = [string]
      $EmplacementFichier = "$varCheminRepertoireScript\$NomFichieraLire"
      $MonFichier = get-content $EmplacementFichier
     
      $NumeroDeLine = 0
      $LigneRef = 0
      foreach ($UneLigne in $MonFichier){
          $NumeroDeLine++
          if ($UneLigne -match 'RAR451' -eq $true) { #Lignes qui contiennent le mot RAR451
              $MyLine = "Ligne $($NumeroDeLine) : $($UneLigne)"
              $LigneRef = $NumeroDeLine + 68
              #Write-host $MyLine
              #add-content $MonFichierAvecLeResultat $MyLine
          }
          if ($NumeroDeLine -lt $LigneRef){
              $MyLine = "$($UneLigne)"
              add-content $MonFichierAvecLeResultat $MyLine
          }
      }
     
     }

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

Discussions similaires

  1. Découper un fichier texte
    Par Kreepz dans le forum VB.NET
    Réponses: 12
    Dernier message: 17/07/2014, 09h05
  2. [2008] Découper un fichier texte avec séparateur ";"
    Par Daniel MOREAU dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 10/04/2014, 17h17
  3. Réponses: 2
    Dernier message: 14/12/2009, 11h36
  4. [Batch] Découper un fichier texte
    Par brolon dans le forum Scripts/Batch
    Réponses: 0
    Dernier message: 31/03/2009, 16h06
  5. Découper un fichier texte
    Par idalloul dans le forum Entrée/Sortie
    Réponses: 3
    Dernier message: 07/10/2008, 10h27

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