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

709

    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. Mitä aiot tehdä uudenvuoden aattona

      Mitä olet suunnitellut tekeväsi uudenvuoden aattona ja aiotko ensi vuonna tehdä jotain muutoksia tai uudenvuoden lupauks
      Sinkut
      203
      4445
    2. Marin sitä, Marin tätä, yhyy yhyy, persut jaksaa vollottaa

      On nuo persut kyllä surkeaa porukkaa. Edelleen itkevät jonkun Marinin perään, vaikka itse ovat tuhonneet Suomen kansan t
      Maailman menoa
      69
      3175
    3. Väestönsiirtoa itään?

      Ano "the Russo" Turtiainen sai poliittisen turvapaikan Venäjältä. Pian lähtee varmaan Nazima Nuzima ja Kiljusen väki per
      Helsinki
      88
      1757
    4. Ikävä sinua..

      Kauan on aikaa kulunut ja asioita tapahtunut. Mutta sinä M-ies olet edelleen vain mielessäni. En tiedä loinko sinusta va
      Ikävä
      13
      1347
    5. Muistattekos kuinka persujen Salainen Akentti kävi Putinin leirillä

      Hakemassa jamesbondimaista vakoiluoppia paikan päällä Venäjällä? Siitä ei edes Suomea suojeleva viranomainen saanut puhu
      Maailman menoa
      18
      1326
    6. Vuoden luetuimmat: Mikä on Pelle Miljoonan taiteilijaeläkkeen suuruus?

      Pelle Miljoonan eläkkeen suuruus kiinnosti lukijoita tänä vuonna. Artikkeli on Suomi24 Viihteen luetuimpia juttuja v. 20
      Suomalaiset julkkikset
      23
      1148
    7. Lindtmanin pääministeriys lähenee päivä päivältä

      Suomen kansan kissanpäivät alkavat siitä hetkestä, kun presidentti Stubb on tehnyt nimityksen. Ainoastaan ylin tulodesi
      Maailman menoa
      10
      1111
    8. Kuumalle kaivatulle tiedoksi

      Tykkään susta!
      Ikävä
      50
      1108
    9. Riikka Purra sanoo, että sietokykyni vittumaisiin ihmisiin alkaa olla lopussa.

      https://www.iltalehti.fi/politiikka/a/be8f784d-fa24-44d6-b59a-b9b83b629b28 Riikka Purra sanoo medialle suorat sanat vitt
      Maailman menoa
      248
      1089
    10. Nyt musta tuntuu

      Et alat päästämään kokonaan irti..
      Ikävä
      50
      999
    Aihe