Olen tekemässä ohjelmaa joka käy rivit läpi etsii joka riviltä samat numerot tässä tapauksessa.
Miten teen sen silleen että se avaa tiedoston esim. c:\numerot.txt ja käy rivi riviltä läpi numerot. esim. rivit:
0102030405
0203040506
0304050607
Ja näistä etsii esim. 03 numeroa.
Tein alun mutta en päässy puusta pitkälle:
*/ ------------------------------
For I = 1 to 5
If Mid$(WinNum, i, 1) = Mid$(MyNum, i, 1) Then
strmatch = strmatch & Mid$(WinNum, i, 1)
End If
Next I
Matches = Len(strMatch)
Miten tästä edetä?
Alun osaan mutta ....
12
996
Vastaukset
- jokuvaan
kuinka yksinkertainen ja helppo.
Esimerkissä etsitään siis "03" merkkijonoa, jos se löytyy riviltä, rivi tulostetaan.
Open App.Path & "\numerot.txt" For Input As #1
Do While Not EOF(1)
Line Input #1, rivi
If InStr(1, rivi, "03", vbTextCompare) Then Print rivi
Loop
Close #1- jokuvaan
Tuo App.Path on ohjelman oletushakemisto, siis mistä se ohjelma käynnistetään, tuo numerot.txt tulee olla siinä hakemistossa.
Voit kirjoittaa luonnollisesti koko polun, vaikka "C:\numerot.txt" tai missä se sitten onkaan. - Yksin pulassa...
jokuvaan kirjoitti:
Tuo App.Path on ohjelman oletushakemisto, siis mistä se ohjelma käynnistetään, tuo numerot.txt tulee olla siinä hakemistossa.
Voit kirjoittaa luonnollisesti koko polun, vaikka "C:\numerot.txt" tai missä se sitten onkaan.Miten haetaan kahta numeroa tekstistä esim. 03 lisäksi numeroa "15"??
- pulassa
Miten voi formiin määritellä esimerkiksi kolme lukua joita etsitään. esim. 02, 05 ja 29??
Siis nämä luvut haluaisin itse määrätä? - jokuvaan
pulassa kirjoitti:
Miten voi formiin määritellä esimerkiksi kolme lukua joita etsitään. esim. 02, 05 ja 29??
Siis nämä luvut haluaisin itse määrätä?Lisäämällä Form1 kolme Text-kehystä
kirjoittamalla niihin haettavat merkkijonot.
Jos jokin noista ehdoista toteutuu, rivi tulostuu.
If InStr(1, rivi, Text1.Text, vbTextCompare) Then Print rivi
If InStr(1, rivi, Text2.Text, vbTextCompare) Then Print rivi
If InStr(1, rivi, Text3.Text, vbTextCompare) Then Print rivi - Pulassa
jokuvaan kirjoitti:
Lisäämällä Form1 kolme Text-kehystä
kirjoittamalla niihin haettavat merkkijonot.
Jos jokin noista ehdoista toteutuu, rivi tulostuu.
If InStr(1, rivi, Text1.Text, vbTextCompare) Then Print rivi
If InStr(1, rivi, Text2.Text, vbTextCompare) Then Print rivi
If InStr(1, rivi, Text3.Text, vbTextCompare) Then Print riviEi toimi toi antamasi ehdotus.
en ainakaan minä sitä saa toimimaan.. - pulasa
Pulassa kirjoitti:
Ei toimi toi antamasi ehdotus.
en ainakaan minä sitä saa toimimaan..Lisäys edelliseen... kaikki kolme lukua pitäisi olla kerrallaan haku ehtoina. Ei siis yksitelle vaan kaikki esim. 02,03,05
- jokuvaan
pulasa kirjoitti:
Lisäys edelliseen... kaikki kolme lukua pitäisi olla kerrallaan haku ehtoina. Ei siis yksitelle vaan kaikki esim. 02,03,05
laita ehdot peräkkäin, eli jokaisen ehdon pitää toteutua:
If InStr(1, rivi, Text1.Text, vbTextCompare) Then
If InStr(1, rivi, Text2.Text, vbTextCompare) Then
If InStr(1, rivi, Text3.Text, vbTextCompare) Then Print rivi
End If
End If - Pulassa
jokuvaan kirjoitti:
laita ehdot peräkkäin, eli jokaisen ehdon pitää toteutua:
If InStr(1, rivi, Text1.Text, vbTextCompare) Then
If InStr(1, rivi, Text2.Text, vbTextCompare) Then
If InStr(1, rivi, Text3.Text, vbTextCompare) Then Print rivi
End If
End IfEi toimi toi lauseesi siinä aiemmassa. Kirjoita toimiva coodi
- jokuvaan
Pulassa kirjoitti:
Ei toimi toi lauseesi siinä aiemmassa. Kirjoita toimiva coodi
Siis, tee tekstitiedosto numerot.txt
ja tallenna se johonkin.
Tässä esimerkissä "C:\hakemisto\polku\"
Tee kolme Text-kehystä, Text1, Text2 ja Text3.
ja jos laitat Text1 "01", Text2 "02", Text3 "03"
ja jos kirjoitit tuohon tiedostoon vaikka rivin "01342025903", josta siis löytyy kaikki Text-kehyksissä syöttämäsi arvot, niin kyllä tulostuu näytölle. Ja ei niiden tarvitse olla tuossa järjestyksessä, kunhan vaan kaikki annetut merkkojonot löytyvät riviltä.
Open "C:\hakemisto\polku\numerot.txt" For Input As #1
Do While Not EOF(1)
Line Input #1, rivi
If InStr(1, rivi, Text1.Text, vbTextCompare) Then
If InStr(1, rivi, Text2.Text, vbTextCompare) Then
If InStr(1, rivi, Text3.Text, vbTextCompare) Then Print rivi
End If
End If
Loop
Close #1 - Basillius
jokuvaan kirjoitti:
Siis, tee tekstitiedosto numerot.txt
ja tallenna se johonkin.
Tässä esimerkissä "C:\hakemisto\polku\"
Tee kolme Text-kehystä, Text1, Text2 ja Text3.
ja jos laitat Text1 "01", Text2 "02", Text3 "03"
ja jos kirjoitit tuohon tiedostoon vaikka rivin "01342025903", josta siis löytyy kaikki Text-kehyksissä syöttämäsi arvot, niin kyllä tulostuu näytölle. Ja ei niiden tarvitse olla tuossa järjestyksessä, kunhan vaan kaikki annetut merkkojonot löytyvät riviltä.
Open "C:\hakemisto\polku\numerot.txt" For Input As #1
Do While Not EOF(1)
Line Input #1, rivi
If InStr(1, rivi, Text1.Text, vbTextCompare) Then
If InStr(1, rivi, Text2.Text, vbTextCompare) Then
If InStr(1, rivi, Text3.Text, vbTextCompare) Then Print rivi
End If
End If
Loop
Close #1Eiks toi toimis lyhyemmin:
If (tosi) And (tosi) And (tosi) Then PrintLine
ei tarvis kuin yhden Iffin :) - yksinpulassa
Basillius kirjoitti:
Eiks toi toimis lyhyemmin:
If (tosi) And (tosi) And (tosi) Then PrintLine
ei tarvis kuin yhden Iffin :)olen tuota ehtolausetta kokeillut mutta ei se tee haluttua toimintoa. Eli toisin sanoen ei toimi vaikka pitäisi.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Diesel-ammattilainen kehuu Sanna Marinia
"Sanna Marinin (sd) hallitus loi neljä vuotta sitten väliaikaisen polttoainetukijärjestelmän, kun energianhinnat nousi362749Pitkänperjantain kunniaksi tekoälyn analyysi Riikka Purran kirjoituksesta
🧠 Mitä se kertoo "riikka"-nimimerkin lähijunassa tapahtuneesta? 1. Asenteellinen ja epäasiallinen sävy: Kirjoitus purs122537100 prosentin perintövero korjaisi myös Hitas-ongelman
Moni ei uskalla kieltäytyä perinnöstä maineen menettämisen uhalla, joten sitten tulee näitä tilanteita, joissa joutuu es372258Riikan antisakset leikkaavat bensan hintaa ylöspäin
Sannan aikoina bensaa sai 1,3 euron litrahinnalla ja Riikka leikkasi sen euron ylemmäksi reiluun 2 euroon. Joko on saks201861Olen aika varma
että meidän tiemme risteäminen oli ainutkertainen tapahtuma elämässäni. En tule koskaan kohtaamaan ketään muuta, joka sa491514Iso poliisioperaatio Lapualla
Paikalla oli silminnäkijän mukaan myös kolme ambulanssia. https://www.is.fi/kotimaa/art-2000011924650.html Onko virpo351508- 381453
Sukupuolineutraalit liikennemerkit yksi persujen älynväläys
Samassa rytäkässä kaikki syrjäseutujen bussipysäkkien liikennemerkitkin vaihdettiin, vaikkei bussia ole liikennöinyt enä241351- 241138
- 181073