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 :

Fusion de CSV


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Juin 2021
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel

    Informations forums :
    Inscription : Juin 2021
    Messages : 11
    Par défaut Fusion de CSV
    Bonjour,

    Je souhaiterais fusionner deux fichiers txt/csv dont un fait environ 1200000 lignes à partir d'une colonne commune comme clé.

    Pouvez-vous svp m'aider afin de trouver une démarche avec un traitement rapide ?

    Cordialement

    Raidstorm14

  2. #2
    Expert confirmé

    Homme Profil pro
    Responsable déploiement (SCCM, InTune, GPO)
    Inscrit en
    Juillet 2014
    Messages
    3 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Responsable déploiement (SCCM, InTune, GPO)
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3 218
    Par défaut
    Bonjour,
    Quel type de fusion/modification ? Ajout de certaine colonne ?
    Il y a un fichier de référence (jointure left ou right) ? Ou pas (jointure full) ?

    Il nous faudrait des exemples de fichier d'entrées et la sortie attendue.

    Je pense qu'il faudra passer pas un hashtable pour les performances.

  3. #3
    Membre averti
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Juin 2021
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel

    Informations forums :
    Inscription : Juin 2021
    Messages : 11
    Par défaut POWERSHELL : csv
    Bonjour,

    Merci pour ton retour et c'est la piste que je commence à percevoir mais étant débutant je ne sais pas faire.
    J'ai fait deux fichiers pour exemple ci-joints :
    * Un fichier Base qui peut contenir 12000000 de lignes et un autre "fichier à renseigner" avec 10000....30000 lignes.

    A partir de l'info 1 renseignée dans chaque fichier je souhaite récupérer l'info 2 du fichier base afin de l'intégrer dans l'autre fichier "Fichier à renseigner"

    j'ai utilisé une autre méthode mais je souhaite aller au bout de ma recherche. (j'ai intégré deux tables dans le logiciel dbeaver afin de faire une requête sql)

    Merci d'avance.

    Raidstorm14
    Fichiers attachés Fichiers attachés

  4. #4
    Expert confirmé

    Homme Profil pro
    Responsable déploiement (SCCM, InTune, GPO)
    Inscrit en
    Juillet 2014
    Messages
    3 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Responsable déploiement (SCCM, InTune, GPO)
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2014
    Messages : 3 218
    Par défaut
    Selon tes fichiers d'exemples, voici comment je procéderais

    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
    $file_base = "base.csv"
    $file_rens = "Fichier à renseigner.csv"
    $file_rens_out = "Fichier à renseigner_out.csv"
     
    $csv_base = Import-Csv -LiteralPath $file_base -Delimiter ";" -Encoding UTF8
    $csv_rens = Import-Csv -LiteralPath $file_rens -Delimiter ";" -Encoding UTF8
     
     
    $hash_base = @{}
    foreach($item in $csv_base)
    {
        if (!$hash_base.ContainsKey($item."Info 1"))
        {
            $hash_base.Add([string]$item."Info 1", [string]$item."Info 2")
        }
    }
     
    foreach($item in $csv_rens)
    {
        if ($hash_base.ContainsKey($item."Info 1"))
        {
            $item."Info 2" = $hash_base[$item."Info 1"]
        }
    }
     
    $csv_rens | Export-Csv -LiteralPath $file_rens_out -Delimiter ";" -Encoding UTF8 -NoTypeInformation -Force


    PS : Je n'écrase pas le fichier pour les tests
    PS : Bien sur tout ceci peut être condensé avec des |

Discussions similaires

  1. [PowerShell] powershell: redirection dans un fichier csv
    Par robbydan dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 14/12/2015, 09h17
  2. [PowerShell] Script powershell et fichier .CSV
    Par big_rems dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 09/07/2015, 13h25
  3. Réponses: 2
    Dernier message: 22/02/2012, 20h06
  4. [PowerShell] [PowerShell]Utiliser une colonne d'un fichier csv
    Par Léponge85 dans le forum Scripts/Batch
    Réponses: 6
    Dernier message: 26/02/2009, 11h54
  5. [Powershell] traiter les pipe dans un csv
    Par dferot dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 16/12/2008, 09h52

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