PDA

View Full Version : VBA=copia dati in excel e incolla su word


mariade
29-08-2006, 10:16
Salve ragazzi,
ho un problema nel creare il mio piccolo progetto, praticamente dovrei copiare alcuni dati da excel e inserirli in word, dove c'e' un testo e dei bookmarks.
Son riuscita a creare il collegamento tra excel e word, difatti si apre il documento word attraverso un tasto su excel che dovrebbe copiare in word dove ho inserito testi e bookmarks, ma non mi copia i dati, word e' vuoto.
Quando clicco Copy, mi esce run time error 13 Type mismatch, e mi seleziona questa riga :"wordApp.Selection.TypeText Text = "TelePhone Report"

Vi riporto tutto il codice che dovrebbe aprire il file word e copiare e incollare, quindi solo la seconda parte...

"Private Sub cmdCopy_Click()
Dim wordApp As Object
Set wordApp = CreateObject("Word.Application")
wordApp.Visible = True
'Create a New Word Document
wordApp.Documents.Add Template:="Normal", NewTemplate:=False, DocumentType:=0
wordApp.Selection.TypeText Text = "TelePhone Report"
wordApp.Selection.Style = wordApp.ActiveDocument.Styles("Heading1")
wordApp.Selection.TypeParagraph

'Enter the date
wordApp.Selection.TypeText Text = "Received"
wordApp.Selection.InsertDateTime_
DateTimeFormat = "ddd,MMM dd,yyyy"
InsertAsField = False
DateLanguage = wdEnglishUK
CalendarType = wdCalendarWestern
InsertAsFullWidth = False
wordApp.Selection.TypeParagraph

wordApp.Selection.TypeText_
Text = "Dear Customer, we are sending you tha amount to pay and his details:"
wordApp.Selection.Style = wordApp.ActiveDocument.Styles("Heading2")
wordApp.Selection.TypeParagraph

'Create bookmark for CustomerName
With wordApp.ActiveDocument.Bookmarks.AddRange = wordApp.Selection.Range
Name = "CustomerName"
.DefaultsSorting = wdSortByName
.ShowHidden = False
End With

'Switch To Excel, copy data Customer
AppActivate "Microsoft Excel", False
Application.Goto Reference = "E3"
Selection.CopyText Appearance = xlScreen

'Switch to Word
AppActivate "Microsoft Word", False
'Go to Bookmark "CustomerName"
wordApp.Selection.Goto Name = "CustomerName"
'Paste data
wordApp.Selection.Paste

'Create bookmark for CustomerNumber
With wordApp.ActiveDocument.Bookmarks.AddRange = wordApp.Selection.Range
Name = "CustomerNumber"
.DefaultsSorting = wdSortByName
.ShowHidden = False
End With

'Switch To Excel, copy data Customer
AppActivate "Microsoft Excel", False
Application.Goto Reference = "D3"
Selection.CopyText Appearance = xlScreen

'Switch to Word
AppActivate "Microsoft Word", False
'Go to Bookmark "CustomerName"
wordApp.Selection.Goto Name = "CustomerNumber"
'Paste data
wordApp.Selection.Paste

'Create bookmark for Amount
With wordApp.ActiveDocument.Bookmarks.AddRange = wordApp.Selection.Range
Name = "Amount"
.DefaultsSorting = wdSortByName
.ShowHidden = False
End With

'Switch To Excel, copy data Customer
AppActivate "Microsoft Excel", False
Application.Goto Reference = "H3"
Selection.CopyText Appearance = xlScreen

'Switch to Word
AppActivate "Microsoft Word", False
'Go to Bookmark "CustomerName"
wordApp.Selection.Goto Name = "Amount"
'Paste data
wordApp.Selection.Paste

wordApp.Selection.TypeText_
Text = "Thanks,Regards Eircom "
wordApp.Selection.Style = wordApp.ActiveDocument.Styles("Heading3")
wordApp.Selection.TypeParagraph

wordApp.ChangeFileOpenDirectory localPath

'save Report
ActiveDocument.SaveAsFilename = "Eircom.doc"
FileFormat = wdFormatDocument

End Sub

"

Cosa dite??? :confused:

mariade
29-08-2006, 11:47
:(

mariade
29-08-2006, 13:57
:stordita: :(

uReverendo
29-08-2006, 20:37
Quando clicco Copy, mi esce run time error 13 Type mismatch, e mi seleziona questa riga :"wordApp.Selection.TypeText Text = "TelePhone Report"
Hai dimenticato i ":" dopo text. Prova in questo modo:
wordApp.Selection.TypeText Text:= "TelePhone Report"
oppure wordApp.Selection.TypeText("TelePhone Report")

Ciao.

mariade
30-08-2006, 09:30
Hai dimenticato i ":" dopo text. Prova in questo modo:
wordApp.Selection.TypeText Text:= "TelePhone Report"
oppure wordApp.Selection.TypeText("TelePhone Report")

Ciao.

Ora ho risolto come inserire i testi. :D
Ora pero' mi segnala run time error 438 oggetto non supporta questa proprieta' o metodo segnalandomi questa riga:

With wordApp.ActiveDocument.Bookmarks.AddRange = wordApp.Selection.Range

Cosa dite che dovrei cambiare per inserire in word un bookmark?
Nel frattempo faccio qualche piccola ricerca anch'io.
Grazie ancora tanto! ;)

mariade
30-08-2006, 16:10
:)

uReverendo
30-08-2006, 17:39
With wordApp.ActiveDocument.Bookmarks.AddRange = wordApp.Selection.Range
Name = "Amount"
.DefaultsSorting = wdSortByName
.ShowHidden = False
End With
:rolleyes: Stesso problema :rolleyes:

prova con:
With wordApp.ActiveDocument.Bookmarks
.Add Range:=wordApp.Selection.Range, Name:="CustomerNumber"
.DefaultSorting = wdSortByName
.ShowHidden = False
End With Ciao.

caviccun
30-08-2006, 19:21
Hai dimenticato i ":" dopo text. Prova in questo modo:
wordApp.Selection.TypeText Text:= "TelePhone Report"
oppure wordApp.Selection.TypeText("TelePhone Report")

Ciao.

Non intervengo per dare consigli perchè sei stato esaurientissimo , volevo solo ricordarti che i ":" per le assegnazioni si usano con il pascal o Delhpi , che è poi il compilatore che sto usando adesso , ma penso anche in C++ (in tema di linguaggi visuali ovviamente). Il VB , per convenzione col "vecchio" Basic , usa solo "=".

mariade
31-08-2006, 08:35
Non intervengo per dare consigli perchè sei stato esaurientissimo , volevo solo ricordarti che i ":" per le assegnazioni si usano con il pascal o Delhpi , che è poi il compilatore che sto usando adesso , ma penso anche in C++ (in tema di linguaggi visuali ovviamente). Il VB , per convenzione col "vecchio" Basic , usa solo "=".


ho risolto il mio problema...
ora vado a verificare il resto
grazie tante a tutti! :D

uReverendo
31-08-2006, 11:11
Non intervengo per dare consigli perchè sei stato esaurientissimo , volevo solo ricordarti che i ":" per le assegnazioni si usano con il pascal o Delhpi , che è poi il compilatore che sto usando adesso , ma penso anche in C++ (in tema di linguaggi visuali ovviamente). Il VB , per convenzione col "vecchio" Basic , usa solo "=".
:mbe: :mbe: :mbe:
Ciò che hai scritto è giustissimo... ma purtroppo inappropriato. :O
I ":=" in vba vengono utilizzati per il passaggio di argomenti predefiniti a routine o funzioni. Nel nostro caso la seguente riga
wordApp.Selection.TypeText Text:= "TelePhone Report" non fa nessuna assegnazione, semplicemente passa come parametro Text ciò che segue ":=". Non a caso ho scritto l'equivalente riga wordApp.Selection.TypeText("TelePhone Report")
Ciao.

mariade
31-08-2006, 11:40
senti volevo chiederti ora, dopo il tuo ultimo suggerimento dovrebbe andare infatti si blocca alla riga di codice successiva:

Application.Goto Reference = "E3"

Io ho bisogno che mi copia solo alcune celle, quelle selezionate appunto nel codice, di sicuro ho sbaglaito a scrivere, sai dirmi dov'e' l'errore? :mc:

uReverendo
31-08-2006, 11:56
senti volevo chiederti ora, dopo il tuo ultimo suggerimento dovrebbe andare infatti si blocca alla riga di codice successiva:

Application.Goto Reference = "E3"

Io ho bisogno che mi copia solo alcune celle, quelle selezionate appunto nel codice, di sicuro ho sbaglaito a scrivere, sai dirmi dov'e' l'errore? :mc:
Per accedere al valore di una cella puoi fare in questo modo:
Dim v As Variant
v = ActiveSheet.Cells(3, 5).Value
Cells(3, 5) indica la cella alla riga 3 e alla colonna 5 in pratica indica la cella "E3". Per portare il valore in word fai:
wordApp.Selection.TypeText Text:=v

mariade
31-08-2006, 13:20
ho fatto come hai detto tu aggiungendo altre due celle e chiamam=ndole non v ma y e z e mi seleziona:

wordApp.Selection.TypeText Text:=y

questa riga e tra l'altro ti posto il copia/incolla di quello che viene scritto su word fino a questo punto:

wordApp.Selection.TypeText Text:=v
Telephone Report
31/08/2006
Dear Customer, we are sending you the amount to pay and his details:Marroni

potrai notare la prima riga di testo in word:
"wordApp.Selection.TypeText Text:=v" :confused:

mariade
31-08-2006, 13:42
ma si ferma alle altre variabili che ho specificato. :mc:

mariade
31-08-2006, 15:15
v = ActiveSheet.Cells(3, 5).Value
Dim x As Variant
x = ActiveSheet.Cells(3, 4).Value
Dim z As Variant
z = ActiveSheet.Cells(3, 8).Value

e quando deve scivere la 2nda variabile, da run time error 13 type mismatch.
e seleziona questa riga...
wordApp.Selection.TypeText Text:=x

ho provato a impostarle tutte con v ma dice che l'ho messa due volte. :(

uReverendo
31-08-2006, 18:20
ciao, lascia perdere l'ultimo mio messaggio (pensavo conoscessi il vba) e fai cosi: Dim wordApp As Object
Set wordApp = CreateObject("Word.Application")
wordApp.Visible = True
'Create a New Word Document
wordApp.Documents.Add Template:="Normal", NewTemplate:=False, DocumentType:=0
wordApp.Selection.TypeText Text:="TelePhone Report"
wordApp.Selection.Style = wordApp.ActiveDocument.Styles("Heading1")
wordApp.Selection.TypeParagraph

'Enter the date
wordApp.Selection.TypeText Text:="Received"
wordApp.Selection.InsertDateTime DateTimeFormat:="ddd,MMM dd,yyyy"
InsertAsField = False
DateLanguage = wdEnglishUK
CalendarType = wdCalendarWestern
InsertAsFullWidth = False
wordApp.Selection.TypeParagraph

wordApp.Selection.TypeText Text:="Dear Customer, we are sending you tha amount to pay and his details:"
wordApp.Selection.Style = wordApp.ActiveDocument.Styles("Heading2")
wordApp.Selection.TypeParagraph

'=======================================================
'Create bookmark for CustomerName
With wordApp.ActiveDocument.Bookmarks
.Add Range:=wordApp.Selection.Range, Name:="CustomerName"
.DefaultSorting = wdSortByName
.ShowHidden = False
End With
' Copia il valore della cella E3
ActiveSheet.Range("E3").Copy
'Go to Bookmark "CustomerName"
wordApp.Selection.Goto Name:="CustomerName"
'Paste data
wordApp.Selection.PasteSpecial DataType:=wdPasteText
'=======================================================

' Va a capo
wordApp.Selection.TypeText Text:=vbLf & vbCr

wordApp.Selection.TypeText Text:="Thanks,Regards Eircom "
wordApp.Selection.Style = wordApp.ActiveDocument.Styles("Heading3")
wordApp.Selection.TypeParagraph

'save Report
wordApp.ActiveDocument.SaveAs Filename:="Eircom.doc", FileFormat:=wdFormatDocument
Ovviamente l'ho fatto solo per una cella (E3) poi tu ti fai le altre. Ho corretto anche la parte finale. Infine per farlo funzionare correttamente devi, in VBA, cliccare sul menu strumenti/riferimenti... e assicurarti che la voce "Microsoft Word 11.0 object library" sia spuntata.

mariade
01-09-2006, 08:17
sono una neofita di vba e vb, mi sto approcciando adesso a questo linguaggio di programmazione, che e' il primo tra l'altro.
Grazie tante, ora correggo il tutto. :ave:

mariade
01-09-2006, 09:08
funziona tutto benissimo, grazie tante uReverendo :p