Rechercher : dans
Par :

Macro avec suppression de colonne

Dernière réponse le 21 nov 2007 à 18:48:36 PONCIUS PILATUS, le 19 nov 2007 à 12:04:09 
 Signaler ce message aux modérateurs

Bonjour à toutes et à tous,

Mon niveau en macro excel est archi nul.
Je souhaite régler deux problème différents dans un fichier Excel.

1/ Je dois rechercher et remplacer une vingtaine de nom différents par une autre vingtaine de noms différents.
Aujourd'hui, je le fais manuellement. Je m'amuse beaucoup ! :)

2/ Ensuite, je dois faire les opérations suivantes dans l'ordre:
- enlever la fonction filtre
- supprimer une série de colonnes qui ne me serve à rien
- supprimer la deuxième ligne qui ne me sert à rien
- créer une nouvelle colonne à la fin du tableau restant
- appliquer une RECHERCHEV dans celle ci qui s'appuit sur base qui est dans un autre fichier Excel.

Je vous le dis, je m'amuse beaucoup!!!

Si quelqu'un veux s'amuser avec moi, c'est avec plaisir !

Fred de Rennes

Configuration: Windows XP
Excel 2000
Firefox 2.0.0.9

Meilleures réponses pour « Macro avec suppression de colonne » dans :
Supprimer les doublons dans une colonne Excel VoirPour extraire les doublons dans une colonne Excel : Cliquer sur le menu "Données" "Filtrer" "Filtre élaboré" Dans ce menu, sélectionner la colonne où se trouvent les doublons Cocher la case "Extraire sans doublon" La seule chose est que...
[VBA] Supprimer un mot dans une plage de cellule VoirSi on veut supprimer un mot dans une phrase il suffit de faire une petite macro qui supprime le mot recherché. Là où ça se corse c'est que le mot recherché pourrait être, par exemple "LEMOT" ou "LeMot" ou "lemot" ou encore "LeMot" etc.. Cette...
SQL - Modification de table VoirModification de table Il est possible de supprimer une table grâce à la clause DROP, il existe aussi des commandes moins extrêmes permettant L'ajout de colonnes La modification de colonnes La suppression de colonnes Enfin, il est possible...

1

néné, le 19 nov 2007 à 18:56:35

Bonjour,
1/ Je dois rechercher et remplacer une vingtaine de nom différents par une autre vingtaine de noms différents.
Aujourd'hui, je le fais manuellement. Je m'amuse beaucoup ! :)

EDITION PUIS REMPLACER


2/ Ensuite, je dois faire les opérations suivantes dans l'ordre:
- enlever la fonction filtre

DONNEES PUIS FILTRE "decocher"

- supprimer une série de colonnes qui ne me serve à rien
SELECTION LES COLONNES PUIS CLIC DROIT "supprimer"
- supprimer la deuxième ligne qui ne me sert à rien

SELECTION La LIGNE PUIS CLIC DROIT "supprimer"


- créer une nouvelle colonne à la fin du tableau restant
SELECTION LA COLONNE JUSTE APRES TON TABLEAU PUIS CLIC DROIT "INSERER"

- appliquer une RECHERCHEV dans celle ci qui s'appuit sur base qui est dans un autre fichier Excel.
EXEMPLE:
'=RECHERCHEV(1;calendrier!C7:D23;2;FAUX)
je recherche ce qui est a coté(2colonnes) de 1 sur la page calendrier dans la plage C7:D23

Répondre à néné

2

eriiic, le 19 nov 2007 à 23:41:53

Bonsoir,

heuuuu, néné, je crois que le monsieur dit que c'est ce qu'il fait actuellement ;-)
et qu'il aimerait bien que ça change...

Il faudrait que tu précises :
1) si c'est le mot dans une cellule ou si le mot fait partie d'une chaine dans une cellule qu'il faut remplacer
Mais une macro ne te fera pas gagner de temps si les mots à remplacer changent à chaque fois.
2) tu évoques un filtre, est-ce que ce remplacement a lieu sur toutes la feuille ou seulement sur les lignes visibles ?
3) quelles colonnes doivent disparaitre et est-ce immédiatement après le remplacement ?
4) Quand au recherchev(), avec tant de précision tu risques de te le coltiner à la main encore...

Et le mieux est que tu déposes en plus un extrait de tes fichiers avant modif sur www.cijoint.com et que tu colles le lien ici

eric

Répondre à eriiic

3

PONCIUS PILATUS, le 20 nov 2007 à 10:08:56

Bonjour Eric,

bien vu, c'est effectivement ce que je fais, tous les jours.

Comme tu me l'a suggérer, voici un lien où tu auras accès au fichier.http://download.yousendit.com/D168BF78087483FE

Le but sur ce fichier est d'enlever le filtre
Ensuite supprimer les colonnes N° famille, Famille, PAHT, CUMP, ainsi que les colonnes Valorisé de chaque ville.
Ensuite, supprimer la ligne 2.
et enfin transformer chaque ville par un abréviation simple:
Ex remplacer 0001 CA ARLES par ARL
La même chose pour chaque ville
et enfin formater la largeur des colonnes en automatique

Est-ce automatisable ?

Merci de ton aide Eric.

Fred

Répondre à PONCIUS PILATUS

4

eriiic, le 20 nov 2007 à 19:47:06

Bonsoir,

Oui c'est faisable.
Peut-être après manger...
eric

Répondre à eriiic

5

eriiic, le 20 nov 2007 à 21:21:50

Qu'appeles-tu les colonnes valorisées ? Les colonnes sans titres après chaque ville ?
Et le nombre de ville est-il tjs le même avec tjs les mêmes villes ?

Répondre à eriiic

6

eriiic, le 20 nov 2007 à 21:59:13

Re,

Comme je me doutais un peu de la réponse j'ai fait avec.

Menu 'outils / macro / macros...' lancer 'MiseEnPage'
J'ai fait un cas particulier pour les villes commençant par 'LE '. LE CREUSOT => CRE
Par contre tu parlais d'une 20aine de villes, il n'y en a que 11. Ce nombre est-il appelé à varier ?
Cette macro s'execute sur le classeur actif donc tu peux traiter n'importe quel fichier.

Sub MiseEnPage()
    Dim i As Long
    Application.ScreenUpdating = False
    Cells.MergeCells = False ' supprimer fusion cellules
    Selection.AutoFilter ' supprimer filtre
    Rows("2:2").Delete Shift:=xlUp 'supp ligne 2
    Columns("A:B").Delete Shift:=xlToLeft ' supp colonnes
    Columns("C:D").Delete Shift:=xlToLeft 'supp colonnes
    ' suppression colonnes valorisées
    For i = 26 To 4 Step -2
        Columns(i).Delete Shift:=xlToLeft
    Next i
    ' traitement villes
    For i = 3 To 13
        Cells(1, i) = Mid(Cells(1, i), 9)
        If Left(Cells(1, i), 3) = "LE " Then
            Cells(1, i) = Mid(Cells(1, i), 4)
        End If
        Cells(1, i) = Left(Cells(1, i), 3)
    Columns(i).EntireColumn.AutoFit
    Next i
    Application.ScreenUpdating = True
End Sub


et le fichier avec la macro
http://www.cijoint.fr/cij90788726732300.xls
Teste si c'est vraiment ce que tu voulais, on affinera si besoin.

eric

Répondre à eriiic

7

eriiic, le 20 nov 2007 à 22:46:30

Remplace:
' traitement villes
For i = 3 To 13

par:
' traitement villes
For i = 3 To [C1].End(xlToRight).Column - 1

et la macro sera ok qcq soit le nombre de villes.

eric

Répondre à eriiic

8

PONCIUS PILATUS, le 21 nov 2007 à 09:55:52
  • +1

Eric, t'es un chef.

C'est le résultat que j'attendais.
Merci beaucoup.

je te donne une adresse poubelle fpelhate@laposte.net.

Envoie moi ton adresse postale afin de te remercier.

Si tu es chez Bouygues, envoie moi ton n° de mobile et les 3 premières lettres de ton nom.
J'en fais mon affaire.

Merci encore


Fred de Rennes

Répondre à PONCIUS PILATUS

9

PONCIUS PILATUS, le 21 nov 2007 à 09:56:48

--

Fred de Rennes

Répondre à PONCIUS PILATUS

10

 eriiic, le 21 nov 2007 à 18:48:36

Bonsoir,

Je te remercie mais ta satisfaction et tes remerciements me suffisent.... :-)
Peut-être à une prochaine sur un autre pb
Bonne soirée à toi
eric

Répondre à eriiic