VBA ongelma

VBAntero

Haluan valita aktiiviselta sheetiltä solun A1.
Käsky
Cells(1,1).select
antaa virheilmoituksen "Select method of Range class failed". Mikä tässä voisi olla vikana?

6

327

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • VBAntero

      Edellinen käsky makrossa aktivoi halutun sheetin, ja siihen asti kaikki toimii hienosti, eli kyseinen sheet aktivoituu. Mutta sitten tuon Cells(1,1).Select -käskyn kohdalla saan virheilmoituksen. Sama juttu jos koitan laittaa tilalle Range("A1").Select -käskyn. Oikeinkirjoitus on tarkistettu moneen kertaan. Manuaalisesti solun A1 valitseminen kyllä onnistuu ihan normaalisti, jos kuittaan VBA-virheilmoituksen end-painikkeella.

      • viittaisi siihen, että taulukko ei ole aktiivinen
        tai taulukko on suojattu
        tai solu lukittu.
        Voisiko olla yhdistetty solu?
        välttämättä koodissa ei tartte valita eikä aktivoida mitään jos tehdään esi. laskutoimituksia yms. soluille tai solualueelle
        Mikä on edellinen koodi makrossa , joka aktivoi taulukon.?
        Toimiiko ko. makro jossain toisessa työkirjassa - avaa uusi työkirja ja kokeile koodia.

        Kyllä toi koodisi pitäisi toimia...
        kokeile seuraavia variaatioita

        Sheets("Sheet1"). Activate
        Range("A1").Select

        tai
        Sheets("Sheet1"). Activate
        Sheets("Sheet1").Range("A1").Select

        tai
        Application.GoTo Sheets("Sheet1").Range("A1")

        toimiiko noilla?


      • ...
        kunde kirjoitti:

        viittaisi siihen, että taulukko ei ole aktiivinen
        tai taulukko on suojattu
        tai solu lukittu.
        Voisiko olla yhdistetty solu?
        välttämättä koodissa ei tartte valita eikä aktivoida mitään jos tehdään esi. laskutoimituksia yms. soluille tai solualueelle
        Mikä on edellinen koodi makrossa , joka aktivoi taulukon.?
        Toimiiko ko. makro jossain toisessa työkirjassa - avaa uusi työkirja ja kokeile koodia.

        Kyllä toi koodisi pitäisi toimia...
        kokeile seuraavia variaatioita

        Sheets("Sheet1"). Activate
        Range("A1").Select

        tai
        Sheets("Sheet1"). Activate
        Sheets("Sheet1").Range("A1").Select

        tai
        Application.GoTo Sheets("Sheet1").Range("A1")

        toimiiko noilla?

        Tuo Application.GoTo Sheets("Sheet1").Range("A1") toimi.

        Miksi .select ei tässä yhteydessä toimi, sitä en kyllä vieläkään ymmärrä. Taulukko oli aktiivinen, ei suojattu, ei lukittu, ja kyseessä ei ollut yhdistetty solu. Mutta samapa tuo.

        Solun valintaa käytin siksi, että saisin siihen liitettyä siihen toisesta workbookista kopioidun rivin, enkä ole yleensä saanut pastea toimimaan muuten kuin valinnan kautta. Miten se onnistuisi? Ei ainakaan näin:

        wb1.sheets(1).rows(1).copy
        wb2.sheets(1).rows(1).paste

        eikä näin:

        wb1.sheets(1).rows(1).copy
        wb2.sheets(1).cells(1,1).paste

        normaalisti tekisin näin, tällä kertaa vaan ei toiminut:

        wb1.sheets(1).rows(1).copy
        wb2.sheets(1).activate
        cells(1,1).select '(tähän tökkäsi)
        application.paste


      • ... kirjoitti:

        Tuo Application.GoTo Sheets("Sheet1").Range("A1") toimi.

        Miksi .select ei tässä yhteydessä toimi, sitä en kyllä vieläkään ymmärrä. Taulukko oli aktiivinen, ei suojattu, ei lukittu, ja kyseessä ei ollut yhdistetty solu. Mutta samapa tuo.

        Solun valintaa käytin siksi, että saisin siihen liitettyä siihen toisesta workbookista kopioidun rivin, enkä ole yleensä saanut pastea toimimaan muuten kuin valinnan kautta. Miten se onnistuisi? Ei ainakaan näin:

        wb1.sheets(1).rows(1).copy
        wb2.sheets(1).rows(1).paste

        eikä näin:

        wb1.sheets(1).rows(1).copy
        wb2.sheets(1).cells(1,1).paste

        normaalisti tekisin näin, tällä kertaa vaan ei toiminut:

        wb1.sheets(1).rows(1).copy
        wb2.sheets(1).activate
        cells(1,1).select '(tähän tökkäsi)
        application.paste

        Sub KopioiToisestaToiseen()
        Workbooks("Koe1").Worksheets("Sheet1").Range("A1").Copy Workbooks("Koe2").Worksheets("Sheet1").Range("A1")
        End Sub

        Keep Excelling ;-)
        @Kunde


      • ...
        kunde kirjoitti:

        Sub KopioiToisestaToiseen()
        Workbooks("Koe1").Worksheets("Sheet1").Range("A1").Copy Workbooks("Koe2").Worksheets("Sheet1").Range("A1")
        End Sub

        Keep Excelling ;-)
        @Kunde

        Eikö tuosta puutu jotain, eihän Workbooks("Koe2").Worksheets("Sheet1").Range("A1") kai yksinään mitään tee..? Ja tuo kopioi vain yhden solun, se kyllä onnistuu yleensä pelkällä paste-komennolla, mutta rivin tai muun usean solun alueen liittämistä en ole saanut toimimaan muuta kuin valitsemalla ensin yhden solun (ja sitten paste erikseen).

        Anyhow, nyt törmäsin sitten toiseen ongelmaan. Koodi
        wb1.Sheets("testi").Activate
        testVar = Cells(1, 1).Value

        antaa testVar -muuttujan arvoksi työkirjan wb1 ensimmäisen sheetin (joka ei suinkaan ole "testi") solun A1 arvon, eikä "test"-sheetin solun A1 arvoa. Vaikka ensimmäisen käskyn jälkeen tuo "testi" onkin aktiivisena. Tämä varmaan liittyy tuohon edelliseen ongelmaan, koska sama sheet on kyseessä. Ei ymmärrä...


      • ... kirjoitti:

        Eikö tuosta puutu jotain, eihän Workbooks("Koe2").Worksheets("Sheet1").Range("A1") kai yksinään mitään tee..? Ja tuo kopioi vain yhden solun, se kyllä onnistuu yleensä pelkällä paste-komennolla, mutta rivin tai muun usean solun alueen liittämistä en ole saanut toimimaan muuta kuin valitsemalla ensin yhden solun (ja sitten paste erikseen).

        Anyhow, nyt törmäsin sitten toiseen ongelmaan. Koodi
        wb1.Sheets("testi").Activate
        testVar = Cells(1, 1).Value

        antaa testVar -muuttujan arvoksi työkirjan wb1 ensimmäisen sheetin (joka ei suinkaan ole "testi") solun A1 arvon, eikä "test"-sheetin solun A1 arvoa. Vaikka ensimmäisen käskyn jälkeen tuo "testi" onkin aktiivisena. Tämä varmaan liittyy tuohon edelliseen ongelmaan, koska sama sheet on kyseessä. Ei ymmärrä...

        luulin, että osaat soveltaa...
        koodi pitää olla samalla rivillä, nyt heittää se n tässä 2 riville...

        Sub KopioiToisestaToiseen()
        Workbooks("Koe1").Worksheets("Sheet1").Range("A1").EntireRow.Copy Workbooks("Koe2").Worksheets("Sheet1").Range("A1")
        End Sub


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

    Luetuimmat keskustelut

    1. Hyvää iltaa!

      Mikä on päivän viisaus?
      Ikävä
      16
      457
    2. Näytät kivalta kun nukut

      *zoomaa palohälyttimen kameraa*
      Ikävä
      10
      412
    3. Haittaako jos

      kaivattusi käy tosi usein pissalla ja/tai kakalla?
      Ikävä
      16
      347
    4. Arvaa mitä mies

      Aion pilata elämäsi totaalisesti. Kyllä, totaalisesti.
      Ikävä
      3
      341
    5. Mies mä oon ihan helppo

      Miehelle johon oon ihastunut. Olen harvoin ihastunut, mutta suhun olen. Ei tarvitse kuin pyytää, niin...
      Ikävä
      13
      206
    6. Hyvää yötä

      Janne niminen mies🥰
      Ikävä
      1
      103
    7. 0
      90
    8. Mies olen aika erakko nykyään

      Vanhentunutkin olen muutamana viime vuonna parikyt vuotta. Kun en ennenkään kelvannut, niin tuskin nytkään kelpaan. Lisä
      Tunteet
      0
      90
    9. Kuinka moni palstalaisista on näin hyvässä kondiksessa

      76-vuotias rokkari Rick Springfield esittelee elämäntyyliään : https://www.youtube.com/watch?v=GbxHuNy6d68
      70 plus
      3
      67
    10. Olet onnellinen sinkku

      Näin se on nähtävä.
      Ikävä
      1
      61
    Aihe