Makrolla solut osiin ja taulukoksi

Anonyymi-ap

Pitäisi saada tälläinen makro, enkä itse osaa

Makro jakaa solun osiin ja laittaa tiedot allekkain

Solun sisällä oleva erotinmerkki vaihtelee tilanteittain ja solualueen koko ja sijainti vaihtelee
Yhden kokonaisuuden / tilanteen sisällä kaikki erotinmerkit ovat samat
Yhden solun sisältö ( vaikka B2) on esim.
tammi;helmi;maalis ja määrä vaihtelee
Toisen solun sisältö (vaikka B3) on esim.
maanantai;tiistai;keskiviikko ja määrä vaihtelee
Ja rivimäärä vaihtelee

Makron vastaus olisi:
tammi
helmi
maalis
Välissä yksi tyhjä solu
maanantai
tiistai
keskiviikko

Kun käyttäjä käynnistää makron, hän valitsee inputboxin avulla:
erotin merkin
ja
käsiteltävän sarakkeen, josta makro osaisi ottaa kaikki täytetyt solut käsittelyyn mukaan
ja
Solun, josta alkaen vastaukset tulevat

Löysin netistä makroja, jotka toimivat osittain kuvatun mukaan
Yksi makro tekee juuri noin kuten kuvasin, mutta käyttäjä ei voi tehdä mitään valintoja.
Toisessa makrossa käyttäjä voi valita erotinmerkin inboxilla, mutta makro jakaa vain yhden solun osiin eikä muita valintoja voi tehdä

Tällä palstalla on ollut Excelin vba-koodauksen superosaajia.
Voisitteko tehdä tuollaisen makron?

Kovasti kiitoksia jo etukäteen

1

834

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Anonyymi

      Tarvittavat lähtötidot valitaan tässä InputBoxien sijaan UserFormilla. Tarvitaan kolme TextBoxia ja CommandButtonia (ja oman mielen mukaan muuta):
      TextBox1 - erotin
      TextBox2 - alue, jolta tiedot luetaan. Alueen voi valita CommandButton1:llä
      TextBox3 - solu, josta lähtien tulostetaan. Alueen voi valita CommandButton2:lla
      CommandButton1 - tulostaa rivit alkaen
      CommandButton2 - päivittää luettavaksi alueeksi valittuna olevan alueen
      CommandButton3 - päivittää tulostuksen alkamaan valittuna olevasta solusta

      UserForm1 aukeaa makrolla riveiksi ja jää näkyviin kunnes se suljetaan. Oletuksena tulostettavaksi valitaan rivit, jotka ovat valittuna kun makro käynnistetään ja tulostus tulee siitä yhden rivin päähän.

      Formin moduliin:

      Private Sub CommandButton1_Click()
          tee
      End Sub

      Private Sub CommandButton2_Click()
          UserForm1.TextBox2.Text = osoite(Selection)
      End Sub

      Private Sub CommandButton3_Click()
          UserForm1.TextBox3.Text = tulostusosoite(Selection)
      End Sub

      Private Sub UserForm_Activate()
          UserForm1.TextBox2.Text = osoite(Selection)
          tulostus = osoite(Cells(Selection.Row   Selection.Rows.Count   1, Selection.Column))
          Debug.Print tulostus
          UserForm1.TextBox3.Text = tulostus
      End Sub

      Tavalliseen moduliin:

      Sub riveiksi()
          UserForm1.TextBox2.Text = osoite(Selection)
          UserForm1.TextBox3.Text = tulostusosoite(Cells(Selection.Row   Selection.Rows.Count   1, Selection.Column))
          UserForm1.Show False
      End Sub

      Function osoite(r As Range) As String
          osoite = WorksheetFunction.Substitute(r.Address, "$", "")
      End Function

      Function tulostusosoite(r As Range) As String
          o = osoite(Selection)
          l = InStr(o, ":") - 1
          If l < 0 Then l = Len(o)
          tulostusosoite = Left(o, l)
      End Function

      Sub tee()
          erotin = UserForm1.TextBox1.Text
          Set alue = Range(UserForm1.TextBox2.Text)
          Set tulos = Range(UserForm1.TextBox3.Text)
          r = tulos.Row
          c = tulos.Column
          For Each s In alue
              t = Split(s, erotin)
              For i = 0 To UBound(t)
                  Cells(r, c) = t(i)
                  r = r   1
              Next i
              r = r   1
          Next s
      End Sub

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

    Luetuimmat keskustelut

    1. Purra hyökkää nyt suomalaisen duunarin kimppuun teettämällä mamuilla palkatonta työtä

      Niinpä niin. Persut duunaripuolue, HAH. Joko alkaa kovapäisinkin persu älyämään, että persut ovat Suomen kansan vastain
      Maailman menoa
      291
      11776
    2. Mitä hyvää rikkaiden hyysääminen Suomelle tuonut?

      Minäpä vastaan: ei yhtikäs mitään, vaan pelkkää vahinkoa. Demareiden ansiosta Suomen valtio oli käytännössä vielä 1980-
      Maailman menoa
      139
      10996
    3. Tytti Tuppurainen häpäisi Suomen epäisänmaallisella lausunnollaan USA:n ulkoministerille Rubiolle.

      https://www.is.fi/politiikka/art-2000011816267.html Miksi Tytti Tuppurainen päästetään antamaan typeriä lausuntoja noin
      Maailman menoa
      239
      6315
    4. Purra ehdottaa vaan Tanskan mallia, joka on erittäin hyvä malli

      Purra ehdotti helmikuussa Suomeen Tanskan mallia, jossa maahanmuuttajilta vaaditaan työntekoa sosiaalitukien saamiseksi.
      Maailman menoa
      218
      5162
    5. Kokoomusnuoret: Sosiaalitukien työvelvoitteen tulisi koskea kaikkia

      Riikka Purra on esittänyt, että maahanmuuttajilta tulisi edellyttää palkatonta työtä sosiaalitukien vastineeksi. Kokoom
      Maailman menoa
      162
      3637
    6. Pystyisitkö olla

      Kanssani kaiken sotkun jälkeen? Ainakaan tunteet ei ole loppuneet
      Ikävä
      174
      3528
    7. L/OVER ikuisesti minun

      Aivan järkyttävä sarja. Ei voi olla katsomatta, mutta tuo omat muistot mieleen. Näyttelijät näyttelevät turhankin hyvin
      Ikävä
      50
      2463
    8. Mitä voisit miehenä tehdä?

      Suojellaksesi kaikkia naisia ja että heillä olisi juuri sinun käytöksen takia edes vähän turvallisempaa. Mitä miehenä
      Ikävä
      329
      1970
    9. Jyrki Linnankivi, Jyrki 69 - Goottirokkarista kirkonmieheksi Lappiin!

      Jyrki Linnankivi eli Jyrki 69 on The 69 Eyes -rockyhtyeen vokalisti. Lauluhommien lisäksi hän sanoittaa, säveltää ja sov
      Työ ja opiskelu
      11
      1807
    10. Onnea Maria ja Vilma Amazing Race -voitosta!

      Maria Guzenina ja Vilma Vähämaa voittivat Amazing Race Suomi -kisan. Voiton hetkellä Guzenina paljasti, miksi valitsi Vi
      Tv-sarjat
      17
      1695
    Aihe