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

550

    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. Mikä on kaivattusi etunimi?

      Otsikossa siis on kysymys eriteltynä. Vain oikeat vastaukset hyväksytään.
      Ikävä
      148
      2845
    2. En kestä katsoa

      Sitä miten sinusta on muut kiinnostuneita. Olen kateellinen. Siksi pitäisi lähteä pois
      Ikävä
      94
      1569
    3. Anna minulle anteeksi

      Anna minulle anteeksi. Minä pyydän.
      Ikävä
      140
      1474
    4. Peräti 95 % persujen kannattajista rasisteja

      Kertoo EVA:n teettämä kysely. Pakollista yhdenvertaisuuskoulutusta tarvitsee siis paljon laajempi joukko kuin pelkästää
      Maailman menoa
      361
      1360
    5. Kun viimeksi kohtasitte/näitte

      Mitä olitte tekemässä? Millainen ympäristö oli? Löydetään toisemme...
      Ikävä
      117
      1314
    6. Olet kyllä vaarallisen himokas

      Luova, kaunis, määrätietoinen, pervo, mielenkiintoinen, kovanaama, naisellinen ja erikoinen.
      Ikävä
      99
      1165
    7. Anna vielä vähän vihreää valoa

      Teen sitten siirtoni, nainen. Tiedän, että olet jo varovaisesti yrittänyt lähestyä, mutta siitä on jo aikaa. Jos tunnet
      Ikävä
      15
      881
    8. On minulla suunitelma

      Siitä ei vain tiedä kukaan muu kuin tällä hetkellä minä. Suunnitelma ja varasuunnitelma. Sinun takiasi nainen. Vain s
      Ikävä
      47
      840
    9. Palstan ylivoimaisesti suosituin keskustelunaihe

      Palstan suosituin keskustelunaihe näyttää olevan homoseksuaalisuus. Otsikoiden perusteella voisi kuvitella olevansa Seks
      Luterilaisuus
      254
      787
    10. 55
      754
    Aihe