Excel-taulukossa haamukoodia?

Iso tiedosto

Hei,

Käytössä on Excel 2007 ja olen tehnyt sillä aika monimutkaista laskentaa, mutten nyt mitään tosi "ihmeellistä", paljon linkityksiä taulusta toiseen jne, mutta homma on pysynyt hanskassa.

Tiedoston koko on kuitenkin yhtäkkiä kasvanut yli 17 megaan(!) ja koko kone tietysti ihan jumissa.

Siirryin taulukon loppuun komennolla ctrl-end, jolloin en päätynytkään soluun bc54, kuten oletin, vaan soluun bf1048576 eli onko minulla nyt yli miljoona riviä, joilla muka on jotain?! Yritin poistaa nuo rivit, mutta siihen ei kapasiteetti riittänyt, vaan excel kaatuu.

Ylipäänsäkin jo yksinkertaisen etsi ja korvaa -komennon antaminen aiheuttaa ilmoituksen "toiminto vaikuttaa suureen määrään soluja ja voi kestää useita minuutteja" ja tietoisesti siis olen tehnyt taulukkoon jotain vain alueelle a1-bc54, ja ctrl-end siis vie soluun bf1048576.
(Sen kyllä olen mennyt tekemään, että olen maalannut vasemmasta ylänurkasta koko taulukon ja antanut määritellyt sarakkeen leveyden, mutta ei kai se tähän syynä ole?)

Miten pääsen mahdollisesta haamukoodista eroon?

Kiitos jo etukäteen teille jotka osaatte neuvoa!

6

835

    Vastaukset

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

      Private Sub Workbook_BeforeSave _
      (ByVal SaveAsUI As Boolean, Cancel As Boolean)
      For Each taulukko In ThisWorkbook.Worksheets
      x = taulukko.UsedRange.Rows.Count
      Next taulukko
      End Sub

      tallenna kun olet lisännyt koodiin ja avaa työkirja uudellen ja CTRL End ja testaa toimiiko... ;-)
      Keep Excelling
      Kunde

      • Iso Tiedosto

        Minä kun en makroista mitään tajua.... Eli menin taulukonvalitsimeen, oikea hiiren korva, Näytä koodi ja liitin tuon tekemäsi makron. Mutta pitääkö siinä tosiaan lukea "taulukko"? vai "sheet" vai "worksheet" vai kyseisen taulukon nimi? Kaikkia näitä kokeilin, tulos entinen eli päädyn yli miljoonannelle riville ja tiedoston koko kasvoi muutamalla tavulla ollen nyt 17754 kt. (Niin, ja tietysti tallensin työkirjani xlsm-muodossa.)

        nyyh... :'(


      • Iso Tiedosto kirjoitti:

        Minä kun en makroista mitään tajua.... Eli menin taulukonvalitsimeen, oikea hiiren korva, Näytä koodi ja liitin tuon tekemäsi makron. Mutta pitääkö siinä tosiaan lukea "taulukko"? vai "sheet" vai "worksheet" vai kyseisen taulukon nimi? Kaikkia näitä kokeilin, tulos entinen eli päädyn yli miljoonannelle riville ja tiedoston koko kasvoi muutamalla tavulla ollen nyt 17754 kt. (Niin, ja tietysti tallensin työkirjani xlsm-muodossa.)

        nyyh... :'(

        tolla tavalla mennään taulukon moduuliin. No nyt ollessasi VBA editoripuolella niin sulla pitäisi näkyä VBA project(työkirjan nimi tässä) ikkuna ja siinä pitäisi nyt olla avoinna sen taulukon koodi ikkuna mistä tulit edellä kuvaamallasi tavalla. Samassa ikkunassa näkyy vihreä excel merkkinen ikoni ja teksti ThisWorkbook. Tuplaklikkaa sitä ja liitä koodi ja tallenna.
        Antamani koodin tarkoitus olisi resetoida viimeisnen solu aina kun työkirja suljetaan. Tietenkin voi sen tehdä niinkin, että kun joku arvo muuttuu taulukossa niin tapahtuisi aina resetointi...

        Parempi tapa mennä ThisWorkbook moduuliin on klikata hiiren oikealla vasemmassa yläkulmassa olevaa excel ikonia (File/Tiedosto menun vasemmalla puolella. En nyt tiedä onko 2007 versiossa tätä enää?). Klikkaus avaa suoraan This workbook moduulin ja liitä koodi sinne ja tallenna.

        Toki kun tallennat 2007 muodossa, tiedoston koko kasvaa kanssa. Voit kokeilla tallentamista vanhemmissa Excel muodoissa ja todeta eron.

        No liitän nyt vielä yleismakron, jonka voit suorittaa mistä moduulista tahansa ja testata pelittääkö tää 2007 versiossa...
        eli siirrä kursori allaolevan koodipätkän jollekin riville ja paina F5. Kokeile sitten taulukoissa CTRL END onko viimeinen rivi todellakin oikea?

        Sub Resetoi()
        For Each taulukko In ThisWorkbook.Worksheets
        x = taulukko.UsedRange.Rows.Count
        Next taulukko
        End Sub

        kepp Excelling
        @Kunde


      • Iso Tiedosto
        kunde kirjoitti:

        tolla tavalla mennään taulukon moduuliin. No nyt ollessasi VBA editoripuolella niin sulla pitäisi näkyä VBA project(työkirjan nimi tässä) ikkuna ja siinä pitäisi nyt olla avoinna sen taulukon koodi ikkuna mistä tulit edellä kuvaamallasi tavalla. Samassa ikkunassa näkyy vihreä excel merkkinen ikoni ja teksti ThisWorkbook. Tuplaklikkaa sitä ja liitä koodi ja tallenna.
        Antamani koodin tarkoitus olisi resetoida viimeisnen solu aina kun työkirja suljetaan. Tietenkin voi sen tehdä niinkin, että kun joku arvo muuttuu taulukossa niin tapahtuisi aina resetointi...

        Parempi tapa mennä ThisWorkbook moduuliin on klikata hiiren oikealla vasemmassa yläkulmassa olevaa excel ikonia (File/Tiedosto menun vasemmalla puolella. En nyt tiedä onko 2007 versiossa tätä enää?). Klikkaus avaa suoraan This workbook moduulin ja liitä koodi sinne ja tallenna.

        Toki kun tallennat 2007 muodossa, tiedoston koko kasvaa kanssa. Voit kokeilla tallentamista vanhemmissa Excel muodoissa ja todeta eron.

        No liitän nyt vielä yleismakron, jonka voit suorittaa mistä moduulista tahansa ja testata pelittääkö tää 2007 versiossa...
        eli siirrä kursori allaolevan koodipätkän jollekin riville ja paina F5. Kokeile sitten taulukoissa CTRL END onko viimeinen rivi todellakin oikea?

        Sub Resetoi()
        For Each taulukko In ThisWorkbook.Worksheets
        x = taulukko.UsedRange.Rows.Count
        Next taulukko
        End Sub

        kepp Excelling
        @Kunde

        Olen nyt tehnyt kaiken mitä mieleen tulee ja vielä kiertänyt lipputangonkin, mutta päädyn vaan riville 1048576. Makrot on mielestäni sallittu, koska olen ruksinut kohdan Ota käyttöön kaikki8 makrot. Olen kokeillut pistää antamaasi kaavaa sekä taulukonvalitsimen oikealla klikkauksella että menemällä Kehitystyökalut / visual basic / inset module sekä insert class module ja mitä ikinä olen löytänyt, eikä mikään auta.... :(
        Eikä tuo yleismakrokaan auta, on ilmeisesti tämä 2007 jo liian fiksu.
        Mutta kiitos, Kunde silti että edes yrität auttaa.
        Minä alan nyt tehdä taulukkoa alusta (huoh!)


      • kopioi
        Iso Tiedosto kirjoitti:

        Olen nyt tehnyt kaiken mitä mieleen tulee ja vielä kiertänyt lipputangonkin, mutta päädyn vaan riville 1048576. Makrot on mielestäni sallittu, koska olen ruksinut kohdan Ota käyttöön kaikki8 makrot. Olen kokeillut pistää antamaasi kaavaa sekä taulukonvalitsimen oikealla klikkauksella että menemällä Kehitystyökalut / visual basic / inset module sekä insert class module ja mitä ikinä olen löytänyt, eikä mikään auta.... :(
        Eikä tuo yleismakrokaan auta, on ilmeisesti tämä 2007 jo liian fiksu.
        Mutta kiitos, Kunde silti että edes yrität auttaa.
        Minä alan nyt tehdä taulukkoa alusta (huoh!)

        käytettyä aluetta uuteen taulukkoon ja tallenna sitä...


      • Iso Tiedosto
        kopioi kirjoitti:

        käytettyä aluetta uuteen taulukkoon ja tallenna sitä...

        Koko aamu siinä meni, mutta nyt tiedosto on kunnossa ja kooltaan enää 1,4 mb :)


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

    Luetuimmat keskustelut

    1. Yritän tänään laittaa taajuudet kohdilleen

      Jotta törmätään kirjaimellisesti. Ei tätä kestä enää perttikään. Olet rakas ❤️
      Ikävä
      66
      2328
    2. Onko kaivattusi

      kyltymätön nainen, pystyisitkö olemaan hänelle loputon mies, vai meneekö toisinpäin.
      Ikävä
      38
      1923
    3. Viulu vaiennut

      Eikö pisnikset suju ? Vai miksi pahin yrittäjä vouhka on "kadonnu" maan alle. 🤣
      Suomussalmi
      29
      1646
    4. Vanhuksen varpaankynsien leikkaus 89 euroa...

      Huh huh.......Parturikäynti olisi varmasti ollut 250 euroa? Kallis on suomi nykyään.
      Maailman menoa
      176
      1613
    5. Anne Kukkohovi. Myy likaisia alushousujaan.

      Kuka ihme ostaa jonkun naisen likaisia alushousuja, menee lujaa kyllä tälläkin housujen myyjällä.
      Kotimaiset julkkisjuorut
      100
      1506
    6. Nainen, sellaista tässä ajattelin

      Minulla on olo, että täällä on edelleen joku, jolla on jotain käsiteltävää. Hän ei ole päässyt lähtemään vielä vaan jost
      Ikävä
      185
      1253
    7. Kauanko skuutteja on siedettävä? Ei tietoa liikennesäännöistä, ajellaan miten sattuu ja missä vain.

      Kauanko on kestettävä sähköpotkulautojen terrorismismia? Niillä ajelevat eivät tiedä, tai jos tietävätkin, niin eivät vä
      Maailman menoa
      131
      1238
    8. Kyllä tekee kipeää

      Luopua kaikesta mitä on elämässä saavuttanut😞 ei vaan ole enää yhtäkään hiljaista vuorokautta🤬
      Ikävä
      25
      1156
    9. En mä tiedä mitä tapahtuu

      siis tykkäisitköhän musta oikeasti. Ehkä oot pelannu liikaa rahapelejä, ehkä rakastat tyhjiä arpoja.
      Ikävä
      9
      962
    10. Luotatko kaivattuusi?

      Jos et, mistä kiikastaa?
      Ikävä
      77
      959
    Aihe