Makro-gurut, apua kaivataan !!!

apua

Tiedostossa, olkoon nimi vaikka lauseet, on 2 sarakkeinen taulukko, 1 sarakkeella juokseva numerointi ja saman rivin toisella sarakkeella lause.

Kirjoitan tekstiä, ja tekstin joukkoon pitäisi hakea lause tuolta taulukosta numeron perusteella.

Kirjoitan numeron, painan makron näppäinyhdistelmää tai painiketta;
makro avaa lauseet tiedoston, siirtyy annetun numeron kohdalle, siitä seuraavaan sarakkeeseen, kopioi solun sisällön, sulkee tiedoston, korvaa annetun numeron kopioidulla tekstillä...

Onko mahdollista luoda tuollainen makro ???

1

723

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • olen käyttänyt vastaavaa ohjelmoinnissa. Helppoa laittaa ryhmittäin($) sanomat(lauseet) ja helppo hakea tiedostosta. Tietenkin sen voi tehdä pyytämälläsi tavalla, mutta mielestäni tämä on mukavin ja selkein tapa.

      tee tiedosto C:\lauseet.txt" muotoon

      $10 'aihe1
      kunde testaa1
      kunde testaa2
      kunde testaa3
      $20 'aihe2
      kunde testaa11
      kunde testaa21
      $30 'aihe3
      kunde testaa111
      kunde testaa211
      kunde testaa311
      kunde testaa411
      kunde testaa511

      ja liitä koodi ThisDocument moduuliin...

      kysyy aiheen numeron esim. 20 ja sitten rivinumeron esim. 2 ja kirjoittaa aktiiviseen kohtaan tekstin "kunde testaa21"

      Dim Aihe As Variant
      On Error Resume Next
      Aihe = InputBox("Anna aiheen numero")
      If Aihe = "" Then Exit Sub
      Tekstirivi = InputBox("Anna rivinumero")
      If Tekstirivi = "" Then Exit Sub
      Selection.TypeText LueTeksti("C:\lauseet.txt", Aihe, Tekstirivi)
      End Sub
      Function LueTeksti(strTextFile As String, strDollari As Variant, lngTxtLine As Variant) As Variant

      Dim dollari As String
      Dim Tekstirivi As String
      Dim Rivinumero As Long
      Dim Dollaritesti As Boolean
      Dim Pituus As Long
      Dim Tarkistus As Long
      Dim Oma As Long


      On Error GoTo VIRHE
      dollari = "*$" & strDollari & "*"
      Open strTextFile For Input As #1

      Do While Not EOF(1)
      Line Input #1, Tekstirivi
      If Tekstirivi Like dollari Then
      Dollaritesti = True
      Rivinumero = 0
      End If

      If Dollaritesti = True Then
      If Rivinumero = lngTxtLine Then
      Oma = InStr(1, Tekstirivi, (Chr(39)))
      If Oma > 0 Then
      Pituus = Len(Tekstirivi)
      Tarkistus = InStr(1, Tekstirivi, (Chr(39)))
      If Tarkistus > 0 Then
      LueTeksti = Mid(Tekstirivi, 1, (Tarkistus - 2))
      If LueTeksti = "False" Or LueTeksti = "True" Then
      LueTeksti = CBool(LueTeksti)
      Exit Do
      ElseIf IsNumeric(LueTeksti) = True Then
      LueTeksti = CDbl(LueTeksti)
      Exit Do
      Else
      LueTeksti = CStr(LueTeksti)
      Exit Do
      End If
      End If
      ElseIf Oma = 0 Then
      LueTeksti = Tekstirivi
      If LueTeksti = "False" Or LueTeksti = "True" Then
      LueTeksti = CBool(LueTeksti)
      Exit Do
      ElseIf IsNumeric(LueTeksti) = True Then
      LueTeksti = CDbl(LueTeksti)
      Exit Do
      Else
      LueTeksti = CStr(LueTeksti)
      Exit Do
      End If
      End If
      End If
      Rivinumero = Rivinumero 1
      End If
      Loop
      Close #1
      POISTU:
      If LueTeksti = Empty Then MsgBox "Annettua riviä ei löydy!!!", vbCritical
      Exit Function
      VIRHE:
      Close #1
      MsgBox "Joku meni pieleen!!!", vbCritical
      Resume POISTU
      End Function


      Keep Excelling (Wording)
      @Kunde

      P.S. seuraavaksi varmaan haluatkin tiedot lomakkeelle, josta klikkaamalla sitten suoraan tekstiin... :-)

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

    Luetuimmat keskustelut

    1. Lindtman I vasemmistohallitus aloittaa viimein Suomen kuntoon laittamisen

      Tässä nyt on 3 vuotta seurattu irvokasta kärsimysnäytelmää nimeltään "valtion budjetin tasapainotus by äärioikeisto", ja
      Maailman menoa
      198
      2747
    2. Missä viipyy persujen lupaama euron bensa?

      En edes muista milloin bensapumpussa olisi ollut ykkösellä alkava litrahinta. Missä siis viipyy persujen lupaama euron b
      Maailman menoa
      158
      2465
    3. Kirje, PellePelottomalle.

      Tärkeää olisi luoda ystävyys, että se, jota rakastaa, on samalla paras ystävä ja luotettavin, jolle voi ja uskaltaa luot
      Ikävä
      106
      1152
    4. Meni kyllä aika solmuun

      Meidän tutustuminen 😐
      Ikävä
      64
      941
    5. Martinan hevoset.

      Tämä todella kaunis ja ketterä harmaa hevonen jolla monet kilpailut voitetaan ei ole Martinan.Tytär ratsastaa sillä tait
      Kotimaiset julkkisjuorut
      246
      860
    6. Mistä löytyy naisseuraa sinkkumiehelle?

      Kertokaapas kokeneemmat mistä löytyis naisseuraa sinkulle. Ihan ois eukko nyt tosissaan hakusessa. Tanssipaikat kun on a
      Kuhmo
      21
      853
    7. Voi teitä naisia

      Suudeltiin ja nukuttiin toisissamme kiinni mutta pillua ei tullu, ei edes aamulla. t.38vmies
      Sinkut
      93
      820
    8. Persut jakavat tekoälyllä tehtyjä kuvia maahanmuuttajista somessa

      Eivät mainitse, että ovat tekoälyllä tehtyjä. Eivät näe asiassa mitään ongelmaa. Valehtelijapuolue taas vauhdissa. Unka
      Maailman menoa
      290
      811
    9. Hyvä meininki

      TTP:ssa väkeä tosi runsaasti paikalla. Hyvää ruokaa jälleen ja munkit ja sima erinomaista. Kiitos yrittäjälle! Hieno Vap
      Haapavesi
      22
      738
    10. Onneksi tapasin sut

      Ilman sua olisin jatkanut pään lyömistä seinään eli samanlaisten miesten etsimistä. Tajusin, mikä menee pieleen vasta ku
      Ikävä
      93
      719
    Aihe