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

Langage Perl Discussion :

Modifier un fichier csv


Sujet :

Langage Perl

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Collégien
    Inscrit en
    Avril 2006
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Avril 2006
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Modifier un fichier csv
    Bonjour,

    Débutant en Perl, je bloque sur un exercice.

    J'ai un fichier csv qui est sous cette forme :

    "228079108";"1230313 JEUX XBOX FIFA"
    "247455128";"1549603 xbox GTA V"

    Je ne sais pas si avec un script Perl je pourrais transformer ces lignes en faisant une insertion d'un séparateur comme ";" après les références qui sont en gras comme par exemple :

    Après lancement du script mon nouveau fichier deviendrait :
    "228079108";"1230313";"JEUX XBOX FIFA"
    "247455128";"1549603";" xbox GTA V"

    Merci pour votre aide si cela est possible et pas trop compliqué. On m'a parlé de "SED" et des expressions régulières..Mais je pense que cela n'est pas pour un débutant

  2. #2
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Points : 12 469
    Points
    12 469
    Billets dans le blog
    1
    Par défaut
    Très facile à faire en Perl, mais tu bloques où?

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Collégien
    Inscrit en
    Avril 2006
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Avril 2006
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par Lolo78 Voir le message
    Très facile à faire en Perl, mais tu bloques où?

    Bonjour Lolo78,

    Très facile à faire en Pert, pour un Expert comme vous...mais pour moi qui commence à peine à apprendre le Perl c'est impossible. je bloque rien qu'à la conception du script .

    Pourriez-vous me communiquer le script avec une petite explication comme mes profs au collège si vous avez le temps et si le script n'est pas long à faire.

    Bonne journée à vous Lolo78 et merci.

  4. #4
    Membre chevronné Avatar de dmganges
    Homme Profil pro
    Retraité. Ne recherche pas un emploi.
    Inscrit en
    Septembre 2011
    Messages
    1 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Retraité. Ne recherche pas un emploi.
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2011
    Messages : 1 392
    Points : 2 044
    Points
    2 044
    Par défaut
    Bonjour,
    Si on le fait à ta place tu ne progresseras pas...
    Pour peu que tu colles le code que tu as commencé à écrire il y a plein de spécialistes qui se feront un plaisir de te répondre ici !
    Sylvain Lhullier
    Expressions régulières

  5. #5
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2013
    Messages
    247
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 247
    Points : 406
    Points
    406
    Par défaut
    Citation Envoyé par oraora Voir le message
    Bonjour,

    Débutant en Perl, je bloque sur un exercice.

    J'ai un fichier csv qui est sous cette forme :

    "228079108";"1230313 JEUX XBOX FIFA"
    "247455128";"1549603 xbox GTA V"

    Je ne sais pas si avec un script Perl je pourrais transformer ces lignes en faisant une insertion d'un séparateur comme ";" après les références qui sont en gras comme par exemple :

    Après lancement du script mon nouveau fichier deviendrait :
    "228079108";"1230313";"JEUX XBOX FIFA"
    "247455128";"1549603";" xbox GTA V"

    Merci pour votre aide si cela est possible et pas trop compliqué. On m'a parlé de "SED" et des expressions régulières..Mais je pense que cela n'est pas pour un débutant
    Bon un petit coup de main sur la méthodologie (et reviens dès que tu as du code et que tu bloques on t'aidera):
    - lire ton fichier
    - modifier ta ligne: utilise une regex ce sera le plus simple
    - écrit ta ligne dans un autre fichier (tu ne pourras pas modifier dans le même fichier ou il faut passer par un fichier temporaire et le renommer comme l'original)

  6. #6
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Points : 12 469
    Points
    12 469
    Billets dans le blog
    1
    Par défaut
    Un peu d'aide sur la regex à employer, sous la forme d'un script uniligne à la ligne de commande:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $echo '"228079108";"1230313 JEUX XBOX FIFA"
    "247455128";"1549603 xbox GTA V"
    ' |  perl -pe 's/(;"\d+) /$1; /;'
    "228079108";"1230313; JEUX XBOX FIFA"
    "247455128";"1549603; xbox GTA V"

  7. #7
    Modérateur
    Avatar de ggnore
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 472
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 472
    Points : 4 029
    Points
    4 029
    Par défaut
    Lis ton fichier et écris en une copie, puis renomme éventuellement les 2 fichiers.
    sed -i permet aussi de modifier des lignes à la volée. N'oublie pas de faire des sauvegardes des fichiers d'origine.
    Si tu ne tentes rien, tu n'y arriveras pas
    Toutes les vertus des hommes se perdent dans l’intérêt comme les fleuves se perdent dans la mer.
    N'oubliez pas de consulter les FAQ Linux et les cours et tutoriels Linux

Discussions similaires

  1. Modifier un fichier CSV
    Par rungis dans le forum Excel
    Réponses: 1
    Dernier message: 30/12/2014, 15h48
  2. Réponses: 3
    Dernier message: 24/10/2012, 13h01
  3. Modifier un fichier csv en script shell
    Par Ghorin dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 26/09/2007, 13h43
  4. Ouvrir et modifier plusieurs fichiers .csv.
    Par jackfred dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 17/07/2007, 12h06
  5. Modifier contenu fichier csv
    Par BernardT dans le forum ASP
    Réponses: 3
    Dernier message: 08/07/2006, 01h18

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