» »

access -> word ali excel

access -> word ali excel

marvin42 ::

Iz neke baze v Accessu printam zadeve... vse skupaj je poštimano res lepo, komplicirane tabele, text, itd... Včasih pa bi v to zadevo rad kaj na roke dodal (npr v tabelo vrinil kakšen text ali dodal kakšno opombo) in takrat se znajdem pred težavo. Izvoz v Word ali Excel je v Accessu skoraj neuporaben (je ok, dokler imaš opravka samo s textom, pri tabelah pa ne gre). Zdaj vse skupaj rešujem tako, da shranim kot pdf in potem s kakšnim ocr programom pretvorim v rtf. Zamudno, pa še zanesljivo ni. Ima kdo kakšno lažjo rešitev?
Mostly Harmless

zavajon ::

Kaj pa če bi naredil kar formo v Accessu?
lp

marvin42 ::

stvar mora biti tako preprosta, da lahko vsak človek s par kliki zadevo vrže v word in tam popravlja... vedno gre za drugačne kozmetične popravke, kar je nemogoče vnaprej predvideti in pripraviti.
Mostly Harmless

zavajon ::

Potem naredi wordov template s formo, kjer bo uporabnik izbral, kaj in od kod bi prenašal podatke in makro za prenos nekako takole:

Sub CopyTable()
On Error GoTo CopyTable_E
Dim cnn As New ADODB.connection
Dim rst As New ADODB.Recordset
Dim tbl As Table
Dim flds As ADODB.Fields
Dim fld As ADODB.Field
Dim i&

With cnn
.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\My Documents\test.mdb"
.Open
End With
With rst
.ActiveConnection = cnn
.Source = "select * from TEST"
.CursorType = adOpenForwardOnly
.LockType = adLockReadOnly
.Open
Set flds = .Fields
End With

Set tbl = ActiveDocument.Tables.Add(Range:=Selection.Range, NumRows:=1, NumColumns:=flds.Count, DefaultTableBehavior:=wdWord9TableBehavior, AutoFitBehavior:=wdAutoFitFixed)
With tbl
' glava
For Each fld In flds
i = i + 1
.Rows(1).Cells(i).Select
Selection.TypeText Text:=fld.Name
Next fld
' polni podatke
While Not rst.EOF
Selection.InsertRowsBelow 1
i = 0
For Each fld In flds
i = i + 1
.Rows(.Rows.Count).Cells(i).Select
Selection.TypeText Text:=fld.Value
Next fld
rst.MoveNext
Wend
.Rows(1).Select
Selection.Font.Bold = wdToggle
End With

CopyTable_X:
On Error Resume Next
rst.Close
cnn.Close
Set rst = Nothing
Set cnn = Nothing
Exit Sub
CopyTable_E:
MsgBox Err.Description
Resume CopyTable_X
End Sub

Templatu moraš referencirati "Microsoft ActiveX Data Objects"

lp

marvin42 ::

zanimivo, hvala!
Mostly Harmless

zavajon ::

Aja, pa če nočeš, da bo procedura vidna v seznamu makrojev (t.j. poganja se npr. iz forme, sicer pa je uporabnik ne more pognati), ji daj en dummy argument.


Vredno ogleda ...

TemaSporočilaOglediZadnje sporočilo
TemaSporočilaOglediZadnje sporočilo
»

vba array

Oddelek: Programiranje
12917 (610) Vazelin
»

[VB] datagridview

Oddelek: Programiranje
351930 (1313) korenje3
»

VISUAL BASIC - Makro v wordu - prenos podatkov iz tabel v excel

Oddelek: Programiranje
52879 (2741) FlashM
»

Kako do podatka v queryu iz VisualBasicScripta (VBA) v accessu?

Oddelek: Programiranje
112145 (2030) Fim
»

printanje v VB6.0

Oddelek: Programiranje
7880 (784) Zzzzzzz

Več podobnih tem