Tiettyjen rivien haku tiedostosta

minähänse

Ohjelmani pitäisi siis osata hakea jostain tekstitiedostosta esimerkiksi vaikkapa rivi 2 jossa oleva lause voi olla usealla eri rivillä esimerkiksi jos tiedoston sisältö näyttää tältä:

tässä
on tekstiä
*
rivi1
rivi2
rivi3
rivi4
*
abc123

Jos haluan hakea tuosta tiedostosta vaikkapa 2 jutun eli nuo rivi1, rivi2, rivi3 ja rivi4:sen niin kuinka se tehdään?

7

713

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Orwell

      Tarkoititko mahdollisesti jotain tällaista?

      Dim sLines As String
      Dim sTmp As String

      sLines = vbNullString

      Open [TIEDOSTOPOLKU] For Input As #1
      Do Until EOF(1)
      Line Input #1, sTmp
      If sTmp Like "rivi*" Then sLines = sLines & sTmp & vbCrLf
      Loop
      Close #1

      Pitäsisi palauttaa:
      rivi1
      rivi2
      rivi3
      rivi4

    • Kunde

      Käytän itse tällaista. Kirjoita tekstitiedosto muotoon

      $10
      heippa
      moro
      terve
      $20
      hei
      moi mitä kuuluu?

      ja sitten vain haet seuraavalla proseduurilla tekstin

      Sub Koe()
      x = LueTekstiFile("C:\Testi.txt", "$20", 2)
      MsgBox x
      End Sub

      tämä palauttaa siis moi mitä kuuluu?

      Function LueTekstiFile(TekstiFile As String, Dollar As String, Tekstirivi As Long) As Variant

      Dim Dollarimerkki As String
      Dim Teksti As String
      Dim Rivimäärä As Long
      Dim Dollariteksti As Boolean
      Dim Pituus As Long
      Dim Tarkiste As Long
      Dim Omatarkiste As Long
      Dim Viesti As String

      On Error GoTo virhe
      Dollarimerkki = "*" & Dollar & "*"
      Open TekstiFile For Input As #1
      Do While Not EOF(1)
      Line Input #1, Teksti
      If Teksti Like Dollarimerkki Then
      Dollariteksti = True
      Rivimäärä = 0
      End If

      If Dollariteksti = True Then
      If Rivimäärä = Tekstirivi Then
      Omatarkiste = InStr(1, Teksti, (Chr(39)))
      If Omatarkiste > 0 Then
      Pituus = Len(Teksti)
      Tarkiste = InStr(1, Teksti, (Chr(39)))
      If Tarkiste > 0 Then
      LueTekstiFile = Mid(Teksti, 1, (Tarkiste - 2))
      If LueTekstiFile = "False" Or LueTekstiFile = "True" Then
      LueTekstiFile = CBool(LueTekstiFile)
      Exit Do
      ElseIf IsNumeric(LueTekstiFile) = True Then
      LueTekstiFile = CDbl(LueTekstiFile)
      Exit Do
      Else
      LueTekstiFile = CStr(LueTekstiFile)
      Exit Do
      End If
      End If
      ElseIf Omatarkiste = 0 Then
      LueTekstiFile = Teksti
      If LueTekstiFile = "False" Or LueTekstiFile = "True" Then
      LueTekstiFile = CBool(LueTekstiFile)
      Exit Do
      ElseIf IsNumeric(LueTekstiFile) = True Then
      LueTekstiFile = CDbl(LueTekstiFile)
      Exit Do
      Else
      LueTekstiFile = CStr(LueTekstiFile)
      Exit Do
      End If
      End If
      End If
      Rivimäärä = Rivimäärä 1
      End If
      Loop

      Close #1
      virhepoistu:
      Exit Function
      virhe:
      Close #1
      Viesti = Err.Description & " " & Err.Number
      MsgBox Viesti, vbCritical, "Tiedostosta luku"
      Resume virhepoistu
      End Function

      • minähänse

        ...mutta tuossa on määriteltävä minkä yksittäisen rivin haluan hakea siitä.

        x = LueTekstiFile("C:\Testi.txt", "$20", 2)
        Siis tämähän hakee vain tuon 2 rivin tuosta "$20" kohdasta eli tuon "moi mitä kuuluu?", mutta kuinka saisin siten, että se hakisi ne kaikki muutkin rivit myöskin tuon "hei" sanan riippumatta siitä kuinka monta riviä siinä on aina tekstiä.


      • Orwell
        minähänse kirjoitti:

        ...mutta tuossa on määriteltävä minkä yksittäisen rivin haluan hakea siitä.

        x = LueTekstiFile("C:\Testi.txt", "$20", 2)
        Siis tämähän hakee vain tuon 2 rivin tuosta "$20" kohdasta eli tuon "moi mitä kuuluu?", mutta kuinka saisin siten, että se hakisi ne kaikki muutkin rivit myöskin tuon "hei" sanan riippumatta siitä kuinka monta riviä siinä on aina tekstiä.

        Tarkoituksesi oli siis lukea *-merkin välissä olevat rivit?

        Dim bStart As Boolean
        Dim sLines As String
        Dim sTmp As String

        bStart = False
        sLines = vbNullString

        Open App.Path & "\test.txt" For Input As #1
        Do Until EOF(1)
        Line Input #1, sTmp

        If Trim$(sTmp) = "*" And Not bStart Then
        bStart = True
        ElseIf Trim$(sTmp) = "*" And bStart Then
        bStart = False
        ElseIf bStart Then
        sLines = sLines & sTmp & vbCrLf
        End If
        Loop
        Close #1

        Tämä koodin pätkä palauttaa *-merkkien välistä kaikki rivit, vaikka niitä olisi useampi.


      • minähänse
        Orwell kirjoitti:

        Tarkoituksesi oli siis lukea *-merkin välissä olevat rivit?

        Dim bStart As Boolean
        Dim sLines As String
        Dim sTmp As String

        bStart = False
        sLines = vbNullString

        Open App.Path & "\test.txt" For Input As #1
        Do Until EOF(1)
        Line Input #1, sTmp

        If Trim$(sTmp) = "*" And Not bStart Then
        bStart = True
        ElseIf Trim$(sTmp) = "*" And bStart Then
        bStart = False
        ElseIf bStart Then
        sLines = sLines & sTmp & vbCrLf
        End If
        Loop
        Close #1

        Tämä koodin pätkä palauttaa *-merkkien välistä kaikki rivit, vaikka niitä olisi useampi.

        Kyllähän tuo toimii, mutta en hae tuollaista koodia.


      • Kunde
        minähänse kirjoitti:

        Kyllähän tuo toimii, mutta en hae tuollaista koodia.

        Nyt lukee dollarimerkkien välisen tekstin

        Sub Koe()
        x = LueTekstiFile("C:\Testi.txt", "$20")
        MsgBox x
        End Sub

        Function LueTekstiFile(TekstiFile As String, Alkurivi As String) As Variant

        Dim Dollarimerkki As String
        Dim Teksti As String
        Dim Rivimäärä As Long
        Dim Dollariteksti As Boolean
        Dim Pituus As Long
        Dim Tarkiste As Long
        Dim Omatarkiste As Long
        Dim Viesti As String

        On Error GoTo virhe
        Dollarimerkki = "*" & Alkurivi & "*"
        Open TekstiFile For Input As #1
        Do While Not EOF(1)
        Line Input #1, Teksti
        If Teksti Like Dollarimerkki Then
        Dollariteksti = True
        End If

        If Dollariteksti = True Then
        If Teksti = Alkurivi Then GoTo hyppy
        If Teksti Like "*$*" Then GoTo loppu
        LueTekstiFile = LueTekstiFile & Teksti & vbNewLine
        End If
        hyppy:
        Loop
        loppu:
        Close #1
        virhepoistu:
        Exit Function
        virhe:
        Close #1
        Viesti = Err.Description & " " & Err.Number
        MsgBox Viesti, vbCritical, "Tiedostosta luku"
        Resume virhepoistu
        End Function


      • minähänse
        Kunde kirjoitti:

        Nyt lukee dollarimerkkien välisen tekstin

        Sub Koe()
        x = LueTekstiFile("C:\Testi.txt", "$20")
        MsgBox x
        End Sub

        Function LueTekstiFile(TekstiFile As String, Alkurivi As String) As Variant

        Dim Dollarimerkki As String
        Dim Teksti As String
        Dim Rivimäärä As Long
        Dim Dollariteksti As Boolean
        Dim Pituus As Long
        Dim Tarkiste As Long
        Dim Omatarkiste As Long
        Dim Viesti As String

        On Error GoTo virhe
        Dollarimerkki = "*" & Alkurivi & "*"
        Open TekstiFile For Input As #1
        Do While Not EOF(1)
        Line Input #1, Teksti
        If Teksti Like Dollarimerkki Then
        Dollariteksti = True
        End If

        If Dollariteksti = True Then
        If Teksti = Alkurivi Then GoTo hyppy
        If Teksti Like "*$*" Then GoTo loppu
        LueTekstiFile = LueTekstiFile & Teksti & vbNewLine
        End If
        hyppy:
        Loop
        loppu:
        Close #1
        virhepoistu:
        Exit Function
        virhe:
        Close #1
        Viesti = Err.Description & " " & Err.Number
        MsgBox Viesti, vbCritical, "Tiedostosta luku"
        Resume virhepoistu
        End Function

        Anteeksi, että vastaukseni kesti näin kauan ja samalla Kiitoksia todella paljon!
        Tämä oli juuri se mitä tarvitsinkin.
        Koodi toimii erinomaisesti.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. IL - PerSut tykittää - Vaaralliset tappajat vankilaan jopa loppuelämäksi!!

      Entistä rajumpi elinkautinen tulee – Vaaralliset tappajat vankilaan jopa loppuelämäksi Henkirikosten uusijat voidaan ja
      Maailman menoa
      196
      22522
    2. Some kuhisee Sanna Marinista: "Wau"

      Sanna Marinia hehkutetaan. Muun muassa Jodelissa kommentoidaan The Sunday Timesin julkaisemaa kuvaa Marinista. Hän ant
      Maailman menoa
      89
      9737
    3. Sannalla tänään vuorossa The Daily Show

      Eli nyt mennään jo satiirin puolelle. Tuohan on vähän kuten Lindströmin ohjelma Suomessa.
      Maailman menoa
      50
      7687
    4. Äärioikeistopurran nukke Petteri Lapanen paniikissa

      Kun Suomen historian paras pääministeri antoi vankan lausunnon, kuinka "keskustelu politiikassa on käpertynyt lähinnä va
      Maailman menoa
      93
      6469
    5. SIELTÄ SE TULI: Kepu-Kurvinen: "Emme enää lähde punavihreään hallitukseen"

      Nyt muuten nauretaan loppuviikko, että tähänkö kaatui Lindtmanin pääministerihaaveet. "Antti Kurvisen mukaan puolue ei
      Maailman menoa
      190
      6196
    6. Tanskassa lain vaatimana Bovaer tappanut nautoja ja sairastuttanut

      Samaa myrkkyä myös Suomen lehmiin ollut tuloillaan, miten teidän tilalla? https://www.agriland.ie/farming-news/bovaer-m
      Maailman menoa
      62
      5777
    7. Ruotsalaisuuden Päivän virallinen liputuspäivä poistettava VÄLITTÖMÄSTI!

      Suomen valtion ja suomalaisuuden kannalta ei ole minkäänlaisia perusteita liputtaa virallisesti ruotsalaisuuden päivää,
      Maailman menoa
      53
      5269
    8. Täysi ryöpytys Sanna Marinille ulkomailla.

      https://www.iltalehti.fi/ulkomaat/a/f699d84f-fa53-4dba-8718-2c395017fc55 Sanna Marinin kirja saa todella tylyn vastaanot
      Maailman menoa
      50
      5175
    9. HS - Sanna Marinin kirja on priimaluokan vedätys!

      Kirja-arvio|Toivo on tekoja tulisi ensisijaisesti nähdä maineen rahallisen hyödyntämisen voimaannuttavana merkkipaaluna.
      Maailman menoa
      120
      4844
    10. Minja Koskelan "istumista" kertovassa uutisessa ei sanottu persuista mitään

      eli jälleen kerran äärivasemmistolainen valehtelee, hän kun väittää että juuri persut ovat lähetelleet Koskelalle vähemm
      Maailman menoa
      107
      4529
    Aihe