Oprettet ons. d. 01. september 2010 kl. 17:34:56

hnto
hnto (7.553 point. Point ude: 500)

linieskift og ordeling funktion i access 2003

Jeg har i tabellen "tabel1" et "felt1", "felt2" og "felt3"
"felt1" og "felt2" skal lægegs sammen i det resulterende "felt3"
dette er simpelt, men hvad hvis jeg ville følgende...

"Felt3" skal updates efterfølgende til at lave linieskift efter 150 karakterer OG hvis det er midt i et ord, skal den gå til starten af ordet og dele det der.

Kom så drenge og piger :-)

NB.
Den skal laves så den kan køres i en opdateringsforespørgsel på feltet

Skrevet tor. d. 02. september 2010 kl. 17:32:20| #1

Christian_Belgien
Christian_Belgien (40.122 point)
Det tog sin tid, for det var lidt komplekst.

Foerst en funktion der deler en lang tekst-streng i linier paa maksimalt x karakterer (du vil have 150, jeg brugte for test 25) men altid deler ved slutningen af et helt ord.  Det kan muligvis goeres kortere og mere elegant, men det her virker i min test:

s = "aaaaaaaa....." 'strengen der skal opdeles
v = "" 'den resulterende opdelte saetning
i = 50 'maksimal laengde af en linie
j = 1 'starten af den naeste linie
While Len(s) >= j + i
    t = Mid(s, j, i) 'den maksimale naeste linie
    k = InStrRev(t, " ") 'sidste mellemrum i naeste linie
    u = Mid(s, j, k - 1) 'naeste linie, afslutter ved et helt ord
    v = v & u & Chr(13) & Chr(10) ' den resulterende delte streng
    j = k + j
Wend
v = v & Mid(s, j)

Den saetning der skal opdeles skal saa vaere felt1 + " " + felt2 og det skal bevares i felt3.  Jeg lavede for test en formular1 bundet til tabel1 med textboxene felt1, felt2, og felt3, og med en knap med den foelgende kode i Click() eventen:

Private Sub Knop3_Click()
    Dim s, t, u, v As String
    Dim i, j, k As Integer
    DoCmd.SetWarnings False
    DoCmd.GoToRecord , "Formulier1", acFirst
    Do Until Me.NewRecord
        s = Me.felt1 & " " & Me.felt2
        v = ""
        i = 50 'maksimal laengde af en linie
        j = 1 'starten af den naeste linie
        While Len(s) >= j + i
            t = Mid(s, j, i) 'den maksimale naeste linie
            k = InStrRev(t, " ") 'sidste mellemrum i naeste linie
            u = Mid(s, j, k - 1) 'naeste linie, afslutter ved et helt ord
            v = v & u & Chr(13) & Chr(10) ' den resulterende string delt i linier
            j = k + j
        Wend
        v = v & Mid(s, j)
        Me.felt3 = v
        DoCmd.GoToRecord acDataForm, "Formulier1", acNext
    Loop
    DoCmd.SetWarnings True
End Sub

Skrevet tor. d. 02. september 2010 kl. 19:02:10| #2

hnto
hnto (7.553 point)
kunne du sende databasen (zip) til info snabela anito punktum dk
:-)

Skrevet tor. d. 02. september 2010 kl. 21:29:05| #3

Christian_Belgien
Christian_Belgien (40.122 point)
Jeg mistede min winzip da jeg for nylig maatte geninstallere, men databasen er kun godt 300k, saa jeg haaber den kommer igennem.  Ellers sig til.  Jeg skal alligevel have fat paa winzip igen.

Tabellen indeholder to records hver med et felt1 og et felt2.  I formularen skal du trykke paa knappen.  Saa foejes teksten i de to felter sammen, og der laves linieskift efter det sidste ord i en maksimal 25 tegns linie (25 i stedet for 150 fordi det var nemmere at teste, men du kan i vba koden saette variabel i til den oenskede linie laengte.

Jeg tillader mig at oprette dette som svar idet jeg haaber at min foreslaaede loesning svarer til hvad du oenskede.

Skrevet fre. d. 03. september 2010 kl. 00:33:54| #4

hnto
hnto (7.553 point)
du får bare point for ihærdigheden, så skal jeg nok få det til at virke hvis der skal justeres lidt :-)

nb har lige sendt en mail retur til dig, idet access ikke kunne kende formatet da jeg renamede til .mdb

bare kyl den direkte igennem, idet det mere var i relation til firewall end det var størrelsen jeg frygtede. :-)

tester det i morgen formiddag...

Skrevet fre. d. 03. september 2010 kl. 21:32:22| #5

Jeg ville lægge 2 (eller flere) felter sammen sådan:

Function lines$(lineLength, ParamArray sStr())
    Dim sString, wrd, lastCRPos%
   
    For Each sString In sStr()
        For Each wrd In Split(sString, " ")
            If Len(lines) + Len(wrd) > lineLength + lastCRPos Then
                lines = lines & vbCrLf
                lastCRPos = Len(lines): End If
            lines = lines & wrd & " ": Next: Next
End Function

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Link til et dokument

Oprettet den 10. februar 2012 kl. 14.15
omn giver 60 point for svar | Giv et svar »

Formular med flere paramtre

Oprettet den 9. februar 2012 kl. 16.48
stuegnu giver 100 point for svar | Giv et svar »

Kodemodul ???

Oprettet den 8. februar 2012 kl. 17.05
olejohn giver 200 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger