Millä koodilla

Mikä on se koodinpätkä jolla saadaan esim alla olevassa koodissa kohdistin rullaamaan niin että se on aina siinä kohdin missä tupla esiintyy. Eli kun taulukossa on ensimmäiset 5 riviä kiinnitetty ja siellä on nappi johon koodi on liitetty niin miten saadaan alimmat rivit rullaamaan niin että aina se rivi jossa on tupla on esillä ?

Sub oma_poista_tuplat()
Dim lngSel As Long
Range("A:A").Interior.ColorIndex = xlNone
For i = Cells(Rows.Count, 1).End(xlUp).Row To 2 Step -1
If WorksheetFunction.CountIf(Range("A1:A" & i), Cells(i, 1).Value) > 1 Then
Cells(i, 1).Interior.ColorIndex = 3
lngSel = MsgBox("Tuplatietoja havaittu...Haluatko poistaa", vbYesNoCancel)
If lngSel = vbCancel Then Exit Sub
If lngSel = vbYes Then
Cells(i, 1).EntireRow.Delete
Else
Cells(i, 1).Interior.ColorIndex = xlNone
End If
End If
Next i
End Sub

14

285

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • ...

      ActiveWindow.ScrollRow = i ?

    • Kiitos vastauksestasi. En saa sitä toimimaan tuolla lisäyksellä. Mihin kohti sijoitit sen ?

      • ...

        Oletettavasti ennen riviä lngSel = MsgBox("Tuplatietoja...

        Ei ole tosin Exceliä käytössä.


    • Tulee "Syntax error"

    • Sub oma_poista_tuplat()
      Dim lngSel As Long
      Range("A:A").Interior.ColorIndex = xlNone
      For i = Cells(Rows.Count, 1).End(xlUp).Row To 2 Step -1
      If WorksheetFunction.CountIf(Range("A1:A" & i), Cells(i, 1).Value) > 1 Then
      Cells(i, 1).Interior.ColorIndex = 3
      ActiveWindow.Panes(2).ScrollRow = i
      lngSel = MsgBox("Tuplatietoja havaittu...Haluatko poistaa", vbYesNoCancel)
      If lngSel = vbCancel Then Exit Sub
      If lngSel = vbYes Then
      Cells(i, 1).EntireRow.Delete
      Else
      Cells(i, 1).Interior.ColorIndex = xlNone
      End If
      End If
      Next i
      End Sub

      • Vielä sen verran että kun nyt koodi löytää tuplat se näyttää niistä vain toisen ja sen siinä lukitun rivin alapuolella. Eli en näe mikä se toinen on johon se viittaa. Tämä on tärkeää koska se saattaa löytää tuplan A sarakkeesta mutta tuplien liitetiedot C ja D ja E sarakkeissa ovatkin erilaiset, jolloin poistoa ei suoriteta.

        Malli;

        A
        1
        2 Näille riveille on piirretty makrojen käyttöä varten painikkeet
        3
        4
        5
        -----------------------------------------------------------------------------------
        Tässä kulkee lukittujen rivien raja

        6 Tieto 1
        7 Tieto 1 (koodi näyttää tämän rivillä 6, kun sen pitäisi näyttää rivin 6 tieto
        rivillä 6 )
        8 Tieto2
        9 Tieto 3
        10 Tieto 4
        jne

        Miten saan tuon korjauksen tuohon ?

        Terv

        Jorma


      • jo.mu kirjoitti:

        Vielä sen verran että kun nyt koodi löytää tuplat se näyttää niistä vain toisen ja sen siinä lukitun rivin alapuolella. Eli en näe mikä se toinen on johon se viittaa. Tämä on tärkeää koska se saattaa löytää tuplan A sarakkeesta mutta tuplien liitetiedot C ja D ja E sarakkeissa ovatkin erilaiset, jolloin poistoa ei suoriteta.

        Malli;

        A
        1
        2 Näille riveille on piirretty makrojen käyttöä varten painikkeet
        3
        4
        5
        -----------------------------------------------------------------------------------
        Tässä kulkee lukittujen rivien raja

        6 Tieto 1
        7 Tieto 1 (koodi näyttää tämän rivillä 6, kun sen pitäisi näyttää rivin 6 tieto
        rivillä 6 )
        8 Tieto2
        9 Tieto 3
        10 Tieto 4
        jne

        Miten saan tuon korjauksen tuohon ?

        Terv

        Jorma

        Anteeksi typerä kysymykseni. Lisäsin sinne perään -5 niin sain ne putoamaan lähemmäs rullattavan taulukon keskustaa ja näinhän se onnistui, tietenkin... Tein sen vaan ensin liian hätäisesti ja panin -5 kiinni i niin eihän se toiminut vaan antoi virhettä. No nyt se on täydellinen. Kiitos kaikille keskusteluun osallistujille, jatketaan excelin kanssa.....


    • Kiitos Kunde. Viitsitkö vielä suomentaa tuon ActiveWindow.Panes(2).ScrollRow = i, eli miksi ActiveWindow.ScrollRow = i ei toimi tuossa yhteydessä ? Eli mistä tuo .Panes(2) syntyy ? Kiitollisena "vba kielen ei niin guru vielä"

    • ActiveWindow viittaa aktiiviseen ikkunaan ja kun se jaetaan syntyy Ikkunat(Panes Collection) ja silloin niitä on 2- eli ylempi Pane1 ja alempi Pane2 ja jos viittataan Pane2.rivinro niin se on siis alemman ikkunan rivi ja ylempi olisi sitten Pane1.rivinro.
      pelkästään activewindow on siis oikeesti ylempi ikkuna

      muokkaa vielä niin, että rullaa aina ylemmässä sitä ekaa esiintymää... sitten se on täydellinen ;-)

      • hokasin vasta, että sanoit muilla riveillä on tietoa mitä tsekataan, miksi et sitten tarkista kaikkia kerralla ja ei tartte kysellä...


    • Moi. Se on totta että vois tarkistaa kaikki kerralla ja silloin ei tarvisi kysellä. Mutta kun ongelmana on se että usealla rivillä on vain yksi tieto joka esiintyy tuplana. Tällöin tuota tietoa ei saa poistaa. Se poistetaan vain jos tieto kaikissa sarakkeissa (A, B, C, D, E, F ja G) on yhtenevä, useammalla kuin yhdellä rivillä. Vois tietenkin ajatella että se kävisi kaikki läpi yhdellä kertaa, ja poistaisi vain ne joissa kaikki tieto on yhtenevää riveittäin. Voisitko näyttää tuon koodin ? Onko exceliin mahdollista tehdä sellaista koodia että kun syötän uusille riveille tietoa, tuo koodi toimis taustalla ja jos se löytää juuri samanlaisen joltakin riviltä, se ilmoittaa siitä MsgBoxilla esim (vastaava tieto löytynyt riviltä .... ) ? Tässä oppii samalla aivan huimasti. Kiitos siitä Sinulle. Onko sulle sellaista sähköpostia mihin voin esimerkin laittaa tästä taulukosta ?

    • helpoitenhan toi menee suodattamalla uniikit paikalla ja sitten poistaa piilotetut rivit...
      toka kyssäri: mahdollista on
      ja vika
      [email protected]

    • Lähetin postia

      • paluupostia sait...

        laitan tännekin sen koodin pätkän, koska se on nopea ja cool...

        eli poistaa tuplarivit DAT taulukosta sarakkeista A-G.
        koodi lisää Huuhaa taulukon ja kopioi tiedot sinne DAT taulukosta ja suorittaa erikoissuodatuksen ja kopioi suodatetut tiedot DAT taulukkoon ja poistaa lopuksi Huuhaa taulukon

        Sub Kunden_poista_tuplat()
        Dim nimi As String
        On Error Resume Next
        Application.DisplayAlerts = False
        nimi = Worksheets("Huuhaa").Name
        If Not Err.Number = 0 Then Sheets.Add.Name = "Huuhaa"
        Sheets("Huuhaa").Cells.ClearContents
        On Error GoTo 0
        Sheets("DAT").Activate
        Cells.Copy Sheets("Huuhaa").Range("A1")
        Cells.ClearContents
        Sheets("Huuhaa").Columns("A:G").AdvancedFilter Action:=xlFilterCopy, CopyToRange:=Range("A6"), Unique:=True
        Sheets("Huuhaa").Delete
        Application.DisplayAlerts = True
        End Sub

        Keep EXCELing
        @Kunde


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

    Luetuimmat keskustelut

    1. Kumpi on sekaisempi - Koskenniemi vai Trump?

      Koskenniemi haukkui Trumppia A-studiossa, niin että räkä lensi suusta. Sen sijaan Trump puheessaan sanoi, että Grönlant
      Maailman menoa
      169
      3171
    2. Sannahan laski sähkön ALV:n 10 prosenttiin, Riikka runnoi 25,5 %:iin

      Tässäkin nähdään kumpi on Suomen kansan puolella, ja kumpi omaa vastaan. Putinistipersuille Suomen kansa tulee aina vii
      Maailman menoa
      63
      1985
    3. Kolmen tuiki tavallisen demariahdistelijan nimet julki

      Nyt tiedetään ketkä kolme oli niissä niin tavanomaisissa demarin jokapäiväisissä askareissa avustajia ahdistelemassa. K
      Maailman menoa
      33
      1965
    4. Kaivattusi silmin

      Minkälaisen kuvan olet omasta mielestäsi antanut itsestäsi kaivatullesi?
      Ikävä
      198
      1890
    5. Saisinpa halata sinua joka päivä

      ja kertoa miten paljon sinusta välitän. Vaikka olisi jommalla kummalla huono päivä, väsynyt päivä tai kiireinen päivä, a
      Ikävä
      26
      1880
    6. Riikka Purra perustelee hallituksen leikkauspolitiikkaa

      Odotukset ovat kovat, mutta puhe on poikkeuksellisen onttoa jopa hallituksen omalla mittapuulla. Vastuu työnnetään alas,
      Perussuomalaiset
      83
      1303
    7. Kansalaispalkka ja maksuton joukkoliikenne

      Noilla pienillä parannuksilla saadaan Suomesta taas hitusen parempi paikka peruskansalaiselle, joka elää ekologisesti ja
      Maailman menoa
      91
      1245
    8. Martinan pankkikortti

      Seiska uutisoi, että Martina antoi pankkilortin tyttärilleen. Siinä on vaan sellainen pointti, että pankkikorttia ei saa
      Kotimaiset julkkisjuorut
      244
      1190
    9. Muistattekos kun kaupassa piti pyytää tavarat myyjältä

      Edes kahvipakettia ei saanut itse valita, vaan myyjä nouti sen hyllystä tiskille. Jos osti jauhelihaa, niin se jauhettii
      Maailman menoa
      190
      1186
    10. Kadonnut Kajaanissa

      Yllättävän hyvät kuvat poliisilla, luulisi löytyvän niiden perusteella?
      Kajaani
      24
      1147
    Aihe