Makro usealle riville

Oops.

Taulukon makro toimii vain ensimmäisellä rivillä.

Miten makron saa toimimaan myös alemmilla riveillä, vai pitääkö jokaiselle riville olla oma makro?

4

662

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • mikroo

      makro tekee just mitä sen on ohjelmoija laittanut tekemään.
      Koodi esimerkki auttaisi kummasta ongelmasi ratkaisemisessa...

      • Oops..

        Tällainen koodi pitäisi saada toimimaan useilla riveillä. Tuo toimii vaan 1. rivillä. Makron tehtävänä on jakaa 54 merkkiä pitkä numerosaraja halutun pituisiksi sarjoiksi.

        Mielellään myös alku pitäisi saada siirrettyä esim. riville 3 ja toimia siitä alaspäin jokaisella rivillä.(A3,A4,A5..jne)

        Jos osaisitte muuttaa tuon valmiiksi, niin olisi hyvä. Vertailen sitä sitten oppiakseni löytämään tarvittavat muutokset.

        Lisäksi olisi hyvä, jos tuon makrossa lukuna 8 (siis 8 lukua tuolla rivillä) saisi 6:nnen luvun jälkeen pilkun. (luvut lasketaan myöhemmin yhteen, niin desimaalit saisi näkyviin todellisena)

        Kiitos!
        -------------------------------------------------

        Sub JaaLuku()
        Dim i As Integer
        Dim a As Integer
        a = 1
        Range("B1:H1").NumberFormat = "@"
        For i = 0 To 6
        j = Array(1, 14, 8, 20, 6, 4, 1)(i)
        Cells(1, 2 i) = Mid(Range("A1"), a, j)
        a = a j
        Next
        End Sub


      • Oops.. kirjoitti:

        Tällainen koodi pitäisi saada toimimaan useilla riveillä. Tuo toimii vaan 1. rivillä. Makron tehtävänä on jakaa 54 merkkiä pitkä numerosaraja halutun pituisiksi sarjoiksi.

        Mielellään myös alku pitäisi saada siirrettyä esim. riville 3 ja toimia siitä alaspäin jokaisella rivillä.(A3,A4,A5..jne)

        Jos osaisitte muuttaa tuon valmiiksi, niin olisi hyvä. Vertailen sitä sitten oppiakseni löytämään tarvittavat muutokset.

        Lisäksi olisi hyvä, jos tuon makrossa lukuna 8 (siis 8 lukua tuolla rivillä) saisi 6:nnen luvun jälkeen pilkun. (luvut lasketaan myöhemmin yhteen, niin desimaalit saisi näkyviin todellisena)

        Kiitos!
        -------------------------------------------------

        Sub JaaLuku()
        Dim i As Integer
        Dim a As Integer
        a = 1
        Range("B1:H1").NumberFormat = "@"
        For i = 0 To 6
        j = Array(1, 14, 8, 20, 6, 4, 1)(i)
        Cells(1, 2 i) = Mid(Range("A1"), a, j)
        a = a j
        Next
        End Sub

        näyttäisi mun väsäämältä koodilta...

        nyt rivit 3:100 ja 6.luvun jälkeen pilkku ja 7 solussa 6 desimaalia...
        en ehkä ymmärtänyt kysymystäsi oikein, mutta kuitenkin tossa koodi

        Sub JaaLuku()
        Dim i As Integer
        Dim a As Integer
        Range("B3:H100").NumberFormat = "@"
        For Each solu In Range("A3:A100")
        If Not solu = "" Then
        a = 1
        For i = 0 To 6
        j = Array(1, 14, 8, 20, 6, 4, 6)(i)
        If i = 5 Then
        Cells(solu.Row, 2 i) = Mid(solu, a, j) & ","
        Else
        Cells(solu.Row, 2 i) = Mid(solu, a, j)
        End If

        a = a j
        Next
        End If
        Next

        End Sub


      • Oops..
        kunde kirjoitti:

        näyttäisi mun väsäämältä koodilta...

        nyt rivit 3:100 ja 6.luvun jälkeen pilkku ja 7 solussa 6 desimaalia...
        en ehkä ymmärtänyt kysymystäsi oikein, mutta kuitenkin tossa koodi

        Sub JaaLuku()
        Dim i As Integer
        Dim a As Integer
        Range("B3:H100").NumberFormat = "@"
        For Each solu In Range("A3:A100")
        If Not solu = "" Then
        a = 1
        For i = 0 To 6
        j = Array(1, 14, 8, 20, 6, 4, 6)(i)
        If i = 5 Then
        Cells(solu.Row, 2 i) = Mid(solu, a, j) & ","
        Else
        Cells(solu.Row, 2 i) = Mid(solu, a, j)
        End If

        a = a j
        Next
        End If
        Next

        End Sub

        Kiitos paalautteestasi!
        Jostain syystä en saanut tuota toimimaan, enkä ymmärrä noita koodeja. Kuitenkin tuo koodi olisi toimivana virheenkorjausta ajatellen tosi hyvä. Sen vuoksi olen kiinnostunut saamaan sen toimivaksi.

        Se alkuperäinen koodi on hyvä, mutta tarvisi vaan vähän säätöä. Yritän kertoa esimerkillä, jos se helpottaisi koodin kirjoittamista:

        Syötä allaoleva luku soluun A1

        333333333333333444444445555555555555555555566666677778

        Ja suorita sitten allaoleva makro...
        _______________________________________
        Sub JaaLuku()
        Dim i As Integer
        Dim a As Integer
        a = 1
        Range("B1:H1").NumberFormat = "@"
        For i = 0 To 6
        j = Array(1, 14, 8, 20, 6, 4, 1)(i)
        Cells(1, 2 i) = Mid(Range("A1"), a, j)
        a = a j
        Next
        End Sub
        ------------------------------------------------
        A1:een syötetty luku...
        233333333333333444444445555555555555555555566666677778
        jakautuu muotoon.....

        A1= 233333333333333444444445555555555555555555566666677778
        B1= 2
        C1= 33333333333333
        D1= 44444444
        E1= 55555555555555555555
        F1= 666666
        G1=7777
        H1=8

        Ja nyt ne ongelmat!

        1. Alkuperäisen luku syötetään soluun A1. Tuo syöttöpaikka täytyisi muutaa soluksi B3. (ja sitten muissakin syöttösoluissa, eli B4, B5..jne vaikka B500:n saakka)
        2. Esimerkissä olevat luvut 44444444 pitäisi maada muotoon 444444,44 (eli tuo pilkku sitä myöhempää yhteenlaskua varten)
        3. Koko "systeemi" pitäisi toimia vaikka 500:lla rivillä.

        ( Homma toimisi siis siten, että jokaisen rivin ensimmäinen solu on aina jaettavaksi tarkoitetun luvun syöttösölu )

        Kiitos, että jaksat auttaa!


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

    Luetuimmat keskustelut

    1. 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
      160
      4259
    2. Vilma Nissinen pyytää anteeksi rasistisia lausuntojaan

      Nöyrtyi kuten persut yleensäkin. On kyllä noloa tuollainen vätystely, kun ei ole miestä seisoa omien lausuntojensa takan
      Maailman menoa
      41
      2343
    3. 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ä
      22
      2231
    4. Riikka Purra: "Kokoomus haluaa leikata pienituloisten etuuksista - Se ei meille käy"

      Näin vakuutti persujen Purra edellisten eduskunta vaalien alla,. https://www.ku.fi/artikkeli/4910942-kun-uudessa-videos
      Maailman menoa
      52
      1818
    5. 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
      372
      1730
    6. 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
      22
      1469
    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
      61
      1464
    8. Kapiainen siviiliesimies, Herra suuri Herra

      Sotilaana kyvytön, johtajana munaton ja kotona tossun alla. Se on upseerin uran tuen pää, seinään ajo. Mutta aina löytyy
      Sodankylä
      80
      1354
    9. Pitäisikö ilotulitteiden myynti kieltää?

      Esim jyväskylässä ainakin on ammuttu ilotulitteita päin ihmisiä ja autoja. Samoin Helsingissä? Pitäisikö ilotulitteiden
      Maailman menoa
      86
      1215
    10. Väärä pää tutustumiseen

      Mikä ihme on, että miehet haluavat ensimmäisenä sänkyyn? Onko nykyään niin helppo saada nainen peittojensa alle.. tai pä
      Ikävä
      156
      1197
    Aihe