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

Shell et commandes GNU Discussion :

Supprimer plusieurs lignes à la suite


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Juin 2013
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2013
    Messages : 5
    Par défaut Supprimer plusieurs lignes à la suite
    Bonsoir,

    J'ai un fichier qui ressemble à ca:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    DROP INDEX SwCatDeviceLicenses_Suite ON ampdbuser.SwCatDeviceLicenses;
    DROP INDEX AppListSwCatAss_AppList ON ampdbuser.AppListSwCatAssignments;
    DROP INDEX LicensedSwCatAss_LAppID ON ampdbuser.LicensedSwCatAssignments;
    DROP INDEX SQLS_IDX_ADMGRPXR_1 ON ampdbuser.AdminGroupAssignedRights
    (
        ObjectTypeID ASC,
        AdminGroupID ASC,
        ObjectID ASC,
        ReadAccess ASC
    ) ON ampdbuser."AMP_INDEX";
    Je dois bien évidemment supprimer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    (
        ObjectTypeID ASC,
        AdminGroupID ASC,
        ObjectID ASC,
        ReadAccess ASC
    ) ON ampdbuser."AMP_INDEX";
    et le remplacer par si possible à la ligne d'avant, sinon ca n'est pas important.

    J'ai cherché comment faire avec sed, awk mais je ne trouve que des commandes qui vont supprimer "x" lignes après ou qui vont chercher la même ligne sur plusieurs lignes etc...

    Je suis quand même tombé sur cette page qui est assez complète mais ne répond pas a mon besoin, et bien d'autres....

    Quelqu'un aurait-il une idée?

  2. #2
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 349
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 349
    Par défaut
    Bonjour,

    Aux infos que tu donnes, voici une façon de faire:
    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
    $ cat net.sql
    DROP INDEX SwCatDeviceLicenses_Suite ON ampdbuser.SwCatDeviceLicenses;
    DROP INDEX AppListSwCatAss_AppList ON ampdbuser.AppListSwCatAssignments;
    DROP INDEX LicensedSwCatAss_LAppID ON ampdbuser.LicensedSwCatAssignments;
    DROP INDEX SQLS_IDX_ADMGRPXR_1 ON ampdbuser.AdminGroupAssignedRights
    (
        ObjectTypeID ASC,
        AdminGroupID ASC,
        ObjectID ASC,
        ReadAccess ASC
    ) ON ampdbuser."AMP_INDEX";
    $ sed -e '/(/,/)/d;/\;$/!s/$/\;/' net.sql
    DROP INDEX SwCatDeviceLicenses_Suite ON ampdbuser.SwCatDeviceLicenses;
    DROP INDEX AppListSwCatAss_AppList ON ampdbuser.AppListSwCatAssignments;
    DROP INDEX LicensedSwCatAss_LAppID ON ampdbuser.LicensedSwCatAssignments;
    DROP INDEX SQLS_IDX_ADMGRPXR_1 ON ampdbuser.AdminGroupAssignedRights;
    Mais pas sur que cela fonctionne pour tous les cas.
    Ici, l'algorithme est:
    je supprime tous les lignes qui sont entre '(' et ')' et je rajoute un ';' en fin de ligne si celui-ci est inexistant.

  3. #3
    Membre expérimenté
    Profil pro
    Architecte de système d'information
    Inscrit en
    Mai 2007
    Messages
    248
    Détails du profil
    Informations personnelles :
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Architecte de système d'information
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2007
    Messages : 248
    Par défaut
    Bonjour,
    sinon

    Reste a ajouter le ; en fin de ligne si pas de ; en fin de ligne

  4. #4
    Membre émérite
    Avatar de f-k-z
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Juin 2006
    Messages
    403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur sécurité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2006
    Messages : 403
    Par défaut
    bonsoir,

    Petite variante de la commande de disedorgue
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -e '/(/,/)/d;/[^\;$]$/s/$/\;/' net.sql
    le fait est que si une ligne est vierge, cela ne rajoute pas de ;
    fafner@Melusine:~/truc$ cat monfichier.sql
    DROP INDEX SwCatDeviceLicenses_Suite ON ampdbuser.SwCatDeviceLicenses;
    DROP INDEX AppListSwCatAss_AppList ON ampdbuser.AppListSwCatAssignments;
    DROP INDEX LicensedSwCatAss_LAppID ON ampdbuser.LicensedSwCatAssignments;
    DROP INDEX SQLS_IDX_ADMGRPXR_1 ON ampdbuser.AdminGroupAssignedRights
    (
    ObjectTypeID ASC,
    AdminGroupID ASC,
    ObjectID ASC,
    ReadAccess ASC
    ) ON ampdbuser."AMP_INDEX";




    fafner@Melusine:~/truc$ sed -e '/(/,/)/d;/[^\;$]$/s/$/\;/' monfichier.sql
    DROP INDEX SwCatDeviceLicenses_Suite ON ampdbuser.SwCatDeviceLicenses;
    DROP INDEX AppListSwCatAss_AppList ON ampdbuser.AppListSwCatAssignments;
    DROP INDEX LicensedSwCatAss_LAppID ON ampdbuser.LicensedSwCatAssignments;
    DROP INDEX SQLS_IDX_ADMGRPXR_1 ON ampdbuser.AdminGroupAssignedRights;




    fafner@Melusine:~/truc$

  5. #5
    Expert confirmé Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 288
    Par défaut
    Bonjour

    Alors, si c'est la foire aux propositions, je donne ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed '/(/{:z;N;/)/!b z;s/.*/\;/}'

Discussions similaires

  1. Substitution sur plusieurs lignes de suite
    Par princebenin dans le forum Langage
    Réponses: 10
    Dernier message: 22/01/2008, 08h19
  2. Supprimé plusieurs ligne?
    Par skorpio dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 12/07/2007, 09h33
  3. VBA supprimer plusieur ligne excel
    Par morgan47 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 20/06/2006, 20h56
  4. [querydataset] supprimer plusieurs lignes
    Par doudine dans le forum JBuilder
    Réponses: 5
    Dernier message: 21/10/2005, 13h21
  5. Supprimer plusieurs lignes d'un DBGrid via Popupmenu?
    Par BVK dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/12/2004, 11h27

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