Erreur 1004 vba excel

Résolu/Fermé
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 - 4 févr. 2010 à 17:17
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 - 11 févr. 2010 à 14:32
Bonjour,

bon voila j'ai fait une macro et je dois sélectionner une cellule pour contrôler si elle vide où non.

j'utilise cette commande : Range(Cells(10, 2)).Select => là ça bug
quand j'utilise : Range("J2").Select => là ça passe :(
je peux pas utiliser la seconde méthode par ce que je souhaite l'introduire dans une boucle for.

voici tout le code

Private Sub transfert_Click()
Dim i, j As Double
Dim f, g As Double
Dim leer As Boolean

'======================= suchen die daten - recherche des données =======================
'control dass es ein datei gibt - contôle de présence de fichier
If classeur1 = vide Then Exit Sub
If classeur2 = vide Then Exit Sub

'öffnen der Datei .csv - ouverture du fichier .csv
Workbooks.Open Filename:=classeur1

'Kopieren die daten von der datei .csv - copier les données du fichier .csv
Cells.Select
Selection.Copy

'öffnen der Datei .xls - ouverture du fichier .xls
NameFichier = ActiveWorkbook.Name
Workbooks.Open Filename:=classeur2

'einfügen die daten in der datei .xls - coller les données dans le fichier .xls
Cells.Select
ActiveSheet.Paste

'schliessen die datei .csv - fermer le fichier.csv
Workbooks(NameFichier).Close

'konvertieren den string -> Koolonne - convertir les chaînes de caractère -> colonne
Columns("A:A").Select
Selection.TextToColumns Destination:=Range("A1"), DataType:=xlDelimited, Semicolon:=True


'====================== Datenverarbeitung - traitement des données ======================

'Definit le nbr de ligne et de colonne de la liste
f = ActiveSheet.UsedRange.Columns.Count
g = ActiveSheet.UsedRange.EntireRow.Count

'leer = 1
'For i = 2 To 256
' link_xls.Text = i
' If Cells(10, 2) <> 0 Then
' leer = leer + 1
' link_csv.Text = leer
' End If
'Next

'If leer = 0 Then
Range(Cells(10, 2)).Select
'Range("J2").Select
If Selection = "" Then
Columns(10).Select
Selection.Delete
End If
End Sub


ps : j'en ai besoin pour un projet au boulot et j'utilise excel 2000, mais il bug aussi chez moi avec excel 2003.

En espérant que vous pourrez m'aider.
A voir également:

25 réponses

tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
4 févr. 2010 à 17:48
Bonjour,
"Range(Cells(10, 2)).Select" => alors premiere chose, cells(10,2) fait référence à B10 et non J2 ( Cells(ligne, colone)
sinon cells(10,2).select suffit par besoin du Range()....
1
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
4 févr. 2010 à 18:17
Sur 2003, ça fonctionne

Mais il me semble que j'avais déjà testé sur la version 2000 et que ça n'avait marcher
je teste demain et je vous donne le résultat

je te remercie aussi pour l'inversion entre ligne et colonne, j'avais pas fait attention à ça
Je te remercie de ton aide tompols
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
5 févr. 2010 à 16:46
ça a bien fonctionné tompols, mais j'ai autre problème du même type
j'essye de renomer un onglet et j'ai la même erreur.

voici le code que j'utilise :

Sub Tri()
classeur2 = Application.GetOpenFilename("*.xls,*.xls")
'ActiveSheets.Name = zeitergeleitet
'Worksheets.Name = zeitergeleitet
'Sheets(1).Name = zeitergeleitet
'Workbooks(classeur2).Save
'Workbooks(classeur2).Close
End Sub

je vous remercie de votre aide
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
5 févr. 2010 à 17:02
Bonjour,
ActiveSheet.name = "zeitergeleitet" 'renomme l'onglet actif
Sheets(1).Name = "zeitergeleitet" 'renomme la feuille 1
Activeworkbook.save 'sauvegarde le classeur actif
Workbooks("classeur2.xls").save 'sauvegarde le classeur Classeur2.xls
voilà :)
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 08:43
en fait voila les problèmes que j'ai :

'ActiveSheets.Name = zeitergeleitet => erreur 424
'Sheets(1).Name = zeitergeleitet => erreur 1004

renommer la première feuille est bien ce que je veux faire
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
8 févr. 2010 à 09:03
Bonjour,
tu n'as pas lu mon poste précédent ???? le nom tu les mets entre guillemets, ensuite c'est activesheet sans s....
0
garion28 Messages postés 1545 Date d'inscription mardi 16 juin 2009 Statut Membre Dernière intervention 3 avril 2011 406
8 févr. 2010 à 09:16
si tu ne met pas de guillemet c'est compté comme une variable, du coup tu essaye de renommer ta feuille avec une valeur null
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 09:41
désolé tompols, je ne l'avais pas vu le "s" en moins
j'ai testé sans le "s" et ça me provoque une erreur 1004...
0
garion28 Messages postés 1545 Date d'inscription mardi 16 juin 2009 Statut Membre Dernière intervention 3 avril 2011 406
8 févr. 2010 à 09:43
as tu remis les guillemet autour de zeitergeleitet ?
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 10:02
Je te remercie, ça fonctionne comme ça; se frappe la tête contre un mur :p

je pense que je risque encore d'avoir des questions à cause de l'erreur 1004, vu sa capacité à me casser les pieds.... :p

=> prochaine étape : programmer un pareto et comprendre les codes que j'ai déjà trouvé
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 10:18
qu'est ce que je disais :(, jai à nouveau cette erreur

voila le code pour le pareto que j'ai trouvé :

Sub Macro1()

ActiveSheet.PivotTables("PivotTable1").PivotCache.Refresh => il big ici
Range("A4").Select
pareto = 0
Selection.Ungroup
For i = 5 To 100
pareto = Range("C" & i).Value + pareto
If pareto >= 0.8 Then
max0 = i + 1
Exit For
End If
Next i
max1 = Range("A4").End(xlDown).Row - 1
Range("A" & max0, "A" & max1).Select
Selection.Group

With ActiveSheet.PivotTables("PivotTable1").PivotFields("Nom Fournisseur2")
.Caption = "Nom Fournisseur "
.PivotItems("Groupe1").Caption = "Reste des fournisseurs"
.PivotItems("Reste des fournisseurs").ShowDetail = False
.AutoSort xlDescending, "Sum of Montant Commandé 2"
End With
ActiveSheet.PivotTables("PivotTable1").PivotFields("Nom Fournisseur"). _
Orientation = xlHidden

End Sub

à priori, il a déjà été testé, je l'ai récupérer ici : https://www.excel-downloads.com/threads/grphique-tcd-avec-pareto.78645/ je vais aussi voir avec eux s'ils voient d'où peut provenir le problème
0
garion28 Messages postés 1545 Date d'inscription mardi 16 juin 2009 Statut Membre Dernière intervention 3 avril 2011 406
8 févr. 2010 à 10:21
d'après l'explorateur d'objet PivotTables demande un index (optionel) en paramètre, hors tu y met un string au lieu du integer
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 11:59
le problème, c'est aue même en applicant l'exemple donné par l'aide, ça bug

voici l'exemple : Worksheets(1).PivotTables(1).PivotCache.Refresh
0
tompols Messages postés 1273 Date d'inscription jeudi 29 juillet 2004 Statut Contributeur Dernière intervention 25 novembre 2013 435
8 févr. 2010 à 12:16
Salut
bon là tu essaies de manipuler le tableau croisé dynamique numéro 1 de ta feuille 1....t'es sur qu'il existe ?
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 13:38
j'essaie de créer le tableau croisé, mais à chaque fois que j'essaie quelque chose je tombe sur l'erreur 1004 :(

voila un exemple :
ActiveWorkbook.PivotCaches.Add(SourceType:=xlDatabase, SourceData:= _
"ramasse!R1C1:R" & lastrow & " C8").CreatePivotTable TableDestination:="", TableName:= _
"Tableau croisé dynamique4"

le problème est que j'ai du mal à voir auoi serve chacun des paramètre
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 15:27
voila om j'arrive :

ActiveWorkbook.PivotCaches.Add SourceType:=xlDatabase, SourceData:= _
"zeitergeleitet!R1C1" & lastrow & lastCol
=> je crée le cache du tableau

ActiveWorkbook.PivotCaches.Item.CreatePivotTable TableDestination:= _
"new!R1C1", TableName:="Tableau", readdata:=True
=> je crée le tableau lui même

le problème c'est que je ne sais pas comment les associés pour avoir ce que je veux
j'ai essayé de l'associé comme c'est fait dans le post du dessus, mais ça ne marche pas non plus

voila mon code :

Sub Tri()
classeur2 = Application.GetOpenFilename("*.xls,*.xls")
If classeur2 = vide Then Exit Sub
Workbooks.Open Filename:=classeur2
Sheets(1).Name = "zeitergeleitet"

Sheets(2).Activate
ActiveSheet.Name = "New"

Dim lastrow As Double
lastrow = ActiveSheet.UsedRange.EntireRow.Count
lastCol = ActiveSheet.UsedRange.Columns.Count

'ActiveWorkbook.PivotCaches.Add(SourceType:=xlDatabase, SourceData:= _
' "zeitergeleitet!A1" & lastrow & lastCol).CreatePivotTable TableDestination:="new", TableName:= _
' "Tableau"

ActiveWorkbook.PivotCaches.Add SourceType:=xlDatabase, SourceData:= _
"zeitergeleitet!R1C1" & lastrow & lastCol

ActiveWorkbook.PivotCaches.Item.CreatePivotTable TableDestination:= _
"new!R1C1", TableName:="Tableau", readdata:=True


ActiveWorkbook.Save
ActiveWorkbook.Close
End Sub

Je vous remercie de votre aide
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
8 févr. 2010 à 19:37
j'ai pu glaner des infos, le problème vient du fais que workbook il prend le classeur où il y a la macro :(

j'ai encore des problème, je cherche de mon coté et je vous demande si je trouve pas moi même

voila le problème :

Workbooks(classeur2).PivotCaches.Add SourceType:=xlDatabase, SourceData:="zeitergeleitet!(R1C1:Cells(lastRow, lastCol))"

sur cette ligne, il me mets erreur 9 : l'indice n'appartient pas à la sélection
comment je peux le faire appartenir ?
0
eriiic Messages postés 24600 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 21 octobre 2024 7 239
8 févr. 2010 à 23:56
Bonsoir,

Ca ne suffira peut-être pas mais tu es faché avec les " " toi...

Workbooks("classeur2") (voire même Workbooks("classeur2.xls") ?)
vue l'heure pas envie de tester ;-)
eric
0
moapremier Messages postés 21 Date d'inscription lundi 16 novembre 2009 Statut Membre Dernière intervention 26 mai 2011 1
9 févr. 2010 à 00:10
c'est pas faux, mais j'ai testé et ça change rien
0
garion28 Messages postés 1545 Date d'inscription mardi 16 juin 2009 Statut Membre Dernière intervention 3 avril 2011 406
9 févr. 2010 à 08:04
zeitergeleitet!(R1C1:Cells(lastRow, lastCol)) si je traduit ca donne:
pour lastrow = 1
pour lastcol = "A"
dans la feuille zeitergeleitet a la sélection R1C1:"A1"

si j'ai bien traduit alors ya un problème (après je ne sais pas ce que représente le R1C1 car je l'ai souvent vu mais jamais utilisé)
0