Avatar billede crunch Nybegynder
28. juni 2004 - 17:24 Der er 2 kommentarer og
1 løsning

replace og do while på tekststreng, gode forslag til metode.

Hej Eksperter,

Jeg kan ikke rigtig finde en smart metode til følgende problem. Jeg har en tekststreng som indeholder en tabel. For hver <td> vil jeg tildele en unik id - men hvordan får jeg nemmest opdelt strengen så jeg løbende får tildelt nye værdier. Nedenstående eksempel virker naturligvis ikke da replace erstatter alle på en gang. Nogen forslag?

Public Function makeids(ByVal strtbl)
        Dim intCount As Integer
        Do While InStr(1, strtbl, "<td>", vbTextCompare) > 0
            strtbl = Replace(strtbl, "<td>", "<td id=" & intCount & ">")
            intCount = intCount + 1
        Loop
        makeids = strtbl
    End Function
Avatar billede arne_v Ekspert
28. juni 2004 - 22:12 #1
Jeg tillader mig at formode at det er VB.NET du ønsker.

Følgende kode er ikke super køn men ser ud til at virke:

    Public Shared Function makeids(ByVal tbl As String) As String
        Dim sb As StringBuilder = New StringBuilder
        Dim oldix As Integer = 0
        Dim ix As Integer = 0
        Dim n As Integer = 0
        ix = tbl.IndexOf("<td>", oldix)
        While ix >= 0
            n = n + 1
            sb.Append(tbl.Substring(oldix, ix - oldix))
            sb.Append("<td id='" & n & "'>")
            oldix = ix + "<td>".Length
            ix = tbl.IndexOf("<td>", oldix)
        End While
        sb.Append(tbl.Substring(oldix))
        Return sb.ToString
    End Function
Avatar billede nielsbrinch Nybegynder
28. juni 2004 - 22:22 #2
Man kan vist undgå en smule af din justering ved at tage den bagfra (med LastIndexOf), men ellers kan jeg ikke se nogen måde at gøre det simplere på. Det ER bare noget rod at skulle bevæge sig gennem en streng.
Avatar billede crunch Nybegynder
29. juni 2004 - 09:11 #3
Jeg siger mange tak (-;
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester