Solun transponointi sarakkeeseen

JariM

Hei,

Tiedoston Taul1 sisältää X riviä tietoa, jokaisella rivillä tietoa on soluissa A:K. Tiedot pitäisi kopioda samaisen tiedoston välilehteen Taul2 sarakkeeseen B niin että yhden rivin tiedot ovat soluissa B1:B11, toisen rivin tiedot soluissa B12:B23, kolmannen rivin tiedot soluissa B24:B35 ja niin edelleen.

Onnistuuko makrolla tuo jotenkin?

21

2014

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • meillä
      • JariM

        Tuo ei skulaa ja sama transponointi onnistuu kyllä Excelissäkin, mutta ongelmaksi tässä muodostuu se, että makron pitäisi transponoida tiedot yhteen sarakkeeseen. Antamassasi esimerkissähän on aivan normaali transponointi, jolloin tiedot kopioituvat kolmelta riviltä kolmeen sarakkeeseen. Tarvitsisin siis jonkin VBA-koodin millä vaikka 250 rivistä saataisiin tiedot kopioitua yhdelle sarakkeelle.


      • niin.
        JariM kirjoitti:

        Tuo ei skulaa ja sama transponointi onnistuu kyllä Excelissäkin, mutta ongelmaksi tässä muodostuu se, että makron pitäisi transponoida tiedot yhteen sarakkeeseen. Antamassasi esimerkissähän on aivan normaali transponointi, jolloin tiedot kopioituvat kolmelta riviltä kolmeen sarakkeeseen. Tarvitsisin siis jonkin VBA-koodin millä vaikka 250 rivistä saataisiin tiedot kopioitua yhdelle sarakkeelle.

        Sorry, luin kysymyksesi hätäisesti. :(


    • rpo

      saat yhdistettyä tietosi yhteen sarakkeeseen.

      Sub YhdistäTiedot()
      Dim tArr As Variant
      Dim i As Integer
      Dim Kohderivi As Integer

      tArr = Array("A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K")

      Sheets("Taul1").Select
      Kohderivi = 1

      For i = 0 To 10
      If i > 0 Then Kohderivi = 2
      Range(tArr(i) & "1:" & tArr(i) & Range(tArr(i) & "65536").End(xlUp).Row).Copy _
      Destination:=Worksheets("Taul2").Cells(Rows.Count, "B").End(xlUp)(Kohderivi)
      Next i
      End Sub

      • JariM

        Tuo on jo niin lähellä, mutta silti niin kaukana. Tuo laittoi Taul2 soluun B1 lähtien Taul1:n kaikki sarakkeen A tiedot allekkain, sitten sarakkeen B tiedot allekkain jne.

        Jos Taul1:ssä on jokaisella rivillä Tulos, Sukunimi, Etunimi, Osoite jne. niin ne pitäisi saada siis allekkain niin että ensiksi on ensimmäisen rivin Tulos, Sukunimi, Etunimi, Osoite... ja ja vasta sitten toisen Tulos, Sukunimi, Etunimi jne.


      • JariM kirjoitti:

        Tuo on jo niin lähellä, mutta silti niin kaukana. Tuo laittoi Taul2 soluun B1 lähtien Taul1:n kaikki sarakkeen A tiedot allekkain, sitten sarakkeen B tiedot allekkain jne.

        Jos Taul1:ssä on jokaisella rivillä Tulos, Sukunimi, Etunimi, Osoite jne. niin ne pitäisi saada siis allekkain niin että ensiksi on ensimmäisen rivin Tulos, Sukunimi, Etunimi, Osoite... ja ja vasta sitten toisen Tulos, Sukunimi, Etunimi jne.

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub

        keep Exceling ;-)
        @Kunde


      • JariM
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub

        keep Exceling ;-)
        @Kunde

        Aivan mahtavaa, kiitoksia =)


      • JariM
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub

        keep Exceling ;-)
        @Kunde

        Hei,

        vielä pitäisi pikkaisen virittäää makroa edellisen pohjalta. Tiedoston Taul1:ssä sarakkeessa A on siis Tulos ja tuloksen kanssa samalla rivillä henkilön tiedot. Mitenkä saan alla olevan makron pohjalta tiedot eriteltyä kolmeen eri välilehteen niin että
        - Taul2:n sarakkeeseen B siirtyvät allekkain niiden rivien tiedot joissa tuloksena (Taul1:n sarake A) on Ympyrä
        - Taul3:n sarakkeeseen B ne, joissa tuloksena on Kolmio ja
        - Taul4:n sarakkeeseen B ne rivit joissa tuloksena on Neliö

        Alla on nimimerkin kunde tekemä makro:
        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub


      • JariM kirjoitti:

        Hei,

        vielä pitäisi pikkaisen virittäää makroa edellisen pohjalta. Tiedoston Taul1:ssä sarakkeessa A on siis Tulos ja tuloksen kanssa samalla rivillä henkilön tiedot. Mitenkä saan alla olevan makron pohjalta tiedot eriteltyä kolmeen eri välilehteen niin että
        - Taul2:n sarakkeeseen B siirtyvät allekkain niiden rivien tiedot joissa tuloksena (Taul1:n sarake A) on Ympyrä
        - Taul3:n sarakkeeseen B ne, joissa tuloksena on Kolmio ja
        - Taul4:n sarakkeeseen B ne rivit joissa tuloksena on Neliö

        Alla on nimimerkin kunde tekemä makro:
        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        Worksheets("Taul3").Range("B:B") = ""
        Worksheets("Taul4").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Offset(0, 1).Resize(1, 11).Copy
        Select Case LCase(solu)
        Case "ympyrä"
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Case "neliö"
        Range("Taul3!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Case "kolmio"
        Range("Taul4!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Case Else
        End Select
        Next
        Application.CutCopyMode = False
        End Sub


      • macroista_tietämätön
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        Worksheets("Taul3").Range("B:B") = ""
        Worksheets("Taul4").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Offset(0, 1).Resize(1, 11).Copy
        Select Case LCase(solu)
        Case "ympyrä"
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Case "neliö"
        Range("Taul3!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Case "kolmio"
        Range("Taul4!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Case Else
        End Select
        Next
        Application.CutCopyMode = False
        End Sub

        Terve!

        Sellaista olisin kysellyt, että mitenkäs jos haluaisi tuosta viestiketjun alussa olevasta esimerkistä
        ottaa tuohon transponointiin vaikka vain A ja C sarakkeet. Eli tuo alla oleva makro toimii muuten mutta, pitäisi saada otettua vain osa sarakkeista mukaan?

        Alla on nimimerkin kunde tekemä makro:
        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub


      • macroista_tietämätön kirjoitti:

        Terve!

        Sellaista olisin kysellyt, että mitenkäs jos haluaisi tuosta viestiketjun alussa olevasta esimerkistä
        ottaa tuohon transponointiin vaikka vain A ja C sarakkeet. Eli tuo alla oleva makro toimii muuten mutta, pitäisi saada otettua vain osa sarakkeista mukaan?

        Alla on nimimerkin kunde tekemä makro:
        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Resize(1, 11).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range

        Worksheets("Taul2").Range("B:B") = ""

        'a- sarake
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next

        'c sarake
        vika = Range("Taul1!C65536").End(xlUp).Row
        For Each solu In Range("Taul1!C1:C" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next

        Application.CutCopyMode = False
        End Sub

        Keep EXCELling
        @Kunde


      • macroista_tietämätön
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range

        Worksheets("Taul2").Range("B:B") = ""

        'a- sarake
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:A" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next

        'c sarake
        vika = Range("Taul1!C65536").End(xlUp).Row
        For Each solu In Range("Taul1!C1:C" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next

        Application.CutCopyMode = False
        End Sub

        Keep EXCELling
        @Kunde

        Tuo edellinen kunde:n tekemä makro laittoi sarakkeen A tiedot ensin Taul2 sarakkeeseen B
        ja siihen perään sarakkeen c tiedot.

        Tarkoitin, että Taul2 sarakkeeseen B tulisi ensin Taul1 solun A1 tieto, sitten solun C1, sitten
        A2, sitten C2.

        kiitoksia kaikista neuvoista.


      • macroista_tietämätön kirjoitti:

        Tuo edellinen kunde:n tekemä makro laittoi sarakkeen A tiedot ensin Taul2 sarakkeeseen B
        ja siihen perään sarakkeen c tiedot.

        Tarkoitin, että Taul2 sarakkeeseen B tulisi ensin Taul1 solun A1 tieto, sitten solun C1, sitten
        A2, sitten C2.

        kiitoksia kaikista neuvoista.

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:C" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub


      • macroista_tietämätön
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Integer
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        For Each solu In Range("Taul1!A1:C" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial Transpose:=True
        Next
        Application.CutCopyMode = False
        End Sub

        kunde,

        tuo edellinen makro toimii muuten, mutta siihen tulee se b sarake mukaan,
        vaikka se pitäisi jättää pois. Eli ainoastaan a ja c pitäisi tulla


      • macroista_tietämätön kirjoitti:

        kunde,

        tuo edellinen makro toimii muuten, mutta siihen tulee se b sarake mukaan,
        vaikka se pitäisi jättää pois. Eli ainoastaan a ja c pitäisi tulla

        Sub Transponoi()
        Dim vika As Long
        Dim vika2 As Long
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        vika2 = Range("Taul1!C65536").End(xlUp).Row
        If vika < vika2 Then
        vika = vika2
        End If
        For Each solu In Range("A1:A" & vika)
        solu.Copy Range("Taul2!B65536").End(xlUp).Offset(1, 0)
        solu.Offset(0, 2).Copy Range("Taul2!B65536").End(xlUp).Offset(1, 0)
        Next
        Application.CutCopyMode = False
        End Sub


      • macroista_tietämätön
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Long
        Dim vika2 As Long
        Dim solu As Range
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        vika2 = Range("Taul1!C65536").End(xlUp).Row
        If vika < vika2 Then
        vika = vika2
        End If
        For Each solu In Range("A1:A" & vika)
        solu.Copy Range("Taul2!B65536").End(xlUp).Offset(1, 0)
        solu.Offset(0, 2).Copy Range("Taul2!B65536").End(xlUp).Offset(1, 0)
        Next
        Application.CutCopyMode = False
        End Sub

        Hei,

        pientä viilausta vielä. Edellinen koodi itsessään toimii, mutta osassa kopioitavista soluista on kaavoja jolloin makro kopio koko kaavan ja liitettäessä muuttaa tietysti indeksöintiä. Olisiko makroa mahdollista muokata niin, että se kopioisi ainoastaan solussa olevan lopputuloksen eikä kaavaa.


      • macroista_tietämätön kirjoitti:

        Hei,

        pientä viilausta vielä. Edellinen koodi itsessään toimii, mutta osassa kopioitavista soluista on kaavoja jolloin makro kopio koko kaavan ja liitettäessä muuttaa tietysti indeksöintiä. Olisiko makroa mahdollista muokata niin, että se kopioisi ainoastaan solussa olevan lopputuloksen eikä kaavaa.

        Sub Transponoi()
        Dim vika As Long
        Dim vika2 As Long
        Dim solu As Range
        On Error Resume Next
        Application.ScreenUpdating = False
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        vika2 = Range("Taul1!C65536").End(xlUp).Row
        If vika < vika2 Then
        vika = vika2
        End If
        For Each solu In Range("A1:A" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        solu.Offset(0, 2).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        Next
        Application.CutCopyMode = False
        Application.ScreenUpdating = True
        End Sub


      • macroista_tietämätön
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Long
        Dim vika2 As Long
        Dim solu As Range
        On Error Resume Next
        Application.ScreenUpdating = False
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        vika2 = Range("Taul1!C65536").End(xlUp).Row
        If vika < vika2 Then
        vika = vika2
        End If
        For Each solu In Range("A1:A" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        solu.Offset(0, 2).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        Next
        Application.CutCopyMode = False
        Application.ScreenUpdating = True
        End Sub

        kiitoksia kundelle erittäin paljon vastauksista, nyt toimii täydellisesti!


      • macroista_tietämätön
        macroista_tietämätön kirjoitti:

        kiitoksia kundelle erittäin paljon vastauksista, nyt toimii täydellisesti!

        Iloitsin sitten liian aikaisin täydellisestä toiminnasta, C sarakkeen arvot hiukan muuttuivat. Osassa C sarakkeen soluissa kaavan lopputulokseksi tulee #N/A, nämä solut pitäisi jättää kopiomatta, mutta kohteena olevaan B sarakkeeseen ei saisi tulla tyhjää solua.

        Esimerkkinä: A1=1, C1=5 B1=1
        A2=2, C2=#N/A B2=5
        A3=3, C3=7 B3=2
        B4=3
        B5=7


      • macroista_tietämätön kirjoitti:

        Iloitsin sitten liian aikaisin täydellisestä toiminnasta, C sarakkeen arvot hiukan muuttuivat. Osassa C sarakkeen soluissa kaavan lopputulokseksi tulee #N/A, nämä solut pitäisi jättää kopiomatta, mutta kohteena olevaan B sarakkeeseen ei saisi tulla tyhjää solua.

        Esimerkkinä: A1=1, C1=5 B1=1
        A2=2, C2=#N/A B2=5
        A3=3, C3=7 B3=2
        B4=3
        B5=7

        Sub Transponoi()
        Dim vika As Long
        Dim vika2 As Long
        Dim solu As Range
        On Error Resume Next
        Application.ScreenUpdating = False
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        vika2 = Range("Taul1!C65536").End(xlUp).Row
        If vika < vika2 Then
        vika = vika2
        End If
        For Each solu In Range("A1:A" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        If Not solu.Offset(0, 2).Text = "#N/A" Then
        solu.Offset(0, 2).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        End If
        Next
        Application.CutCopyMode = False
        Application.ScreenUpdating = True
        End Sub

        Keep EXCELling
        @Kunde


      • macroista_tietämätön
        kunde kirjoitti:

        Sub Transponoi()
        Dim vika As Long
        Dim vika2 As Long
        Dim solu As Range
        On Error Resume Next
        Application.ScreenUpdating = False
        Worksheets("Taul2").Range("B:B") = ""
        vika = Range("Taul1!A65536").End(xlUp).Row
        vika2 = Range("Taul1!C65536").End(xlUp).Row
        If vika < vika2 Then
        vika = vika2
        End If
        For Each solu In Range("A1:A" & vika)
        solu.Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        If Not solu.Offset(0, 2).Text = "#N/A" Then
        solu.Offset(0, 2).Copy
        Range("Taul2!B65536").End(xlUp).Offset(1, 0).PasteSpecial (xlPasteValues)
        End If
        Next
        Application.CutCopyMode = False
        Application.ScreenUpdating = True
        End Sub

        Keep EXCELling
        @Kunde

        Toimii! kiitoksia jälleen kerran.


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

    Luetuimmat keskustelut

    1. Mira Luoti ja Julkkisselviytyjät 2017 - Ketä kuumottaa juuri nyt?

      HS: Tässä ohjelmassa Mira Luoti kertoi kokeneensa seksuaalista väkivaltaa "PMMP-yhtyeen Mira Luoti kertoo Ylen uudessa
      Kotimaiset julkkisjuorut
      73
      2015
    2. Mietin että

      Onko tarinallamme vielä luvussa tilaa kohtaamiselle vai jääkö se tähän.
      Ikävä
      102
      1883
    3. Kaipaatko sinä

      Yhtään meidän katseita
      Ikävä
      142
      1773
    4. Oletko samaa mieltä

      Että on parempi olla erillään?
      Ikävä
      97
      1421
    5. Törkeä eläinsuojelurikos Sonkajärvellä

      Pohjois-Savossa Sonkajärvellä noin 40 kissaa ja reilut 10 koiraa on jouduttu lopettamaan kaltoinkohtelun vuoksi, kertoo
      Sonkajärvi
      35
      1389
    6. MESTARI SIVALTAA JÄLLEEN

      https://www.is.fi/politiikka/art-2000011436243.html Suomen ainoa Mestari lausuu tosiasiat Sannasta , Tuomiojasta ja hil
      Kajaani
      317
      1265
    7. Kirjallinen varoitus

      On annettu eräälle henkilölle. hyssytellään kuitenkin asiasta
      Äänekoski
      60
      1229
    8. Jotkut ihmiset pelkäävät syöpää sairastavaa

      On hauskaa, kun kertoo jollekin, että "minulla on syöpä". Jotkut käyttäytyvät kuin se olisi tarttuva tauti. Eivät uskall
      Sinkut
      130
      1112
    9. Julkisuuden henkilön päiväin päätös

      Sitä vaan, että kyllä nyt kaikki tietävät kuka oli Eemeli Peltola (kansanedustaja, joka päätti päivänsä eduskuntatalossa
      Sinkut
      276
      1066
    10. Kuulin juttua että Jeesus on kopioitu krishnasta

      Pitääkö paikkansa että kertomukset ovat samat kummankin uskonnon kirjoissa
      Hindulaisuus
      446
      963
    Aihe