Kuvan hakeminen Exceliin

Excel-Turo

Osaisiko kukaan antaa neuvoja seuraavaan ongelmaan. Excel-taulukossa pitäisi saada soluun kopioitua kuva joka vastaa toisen solun tekstiä. Eli kun ensimmäiseen soluun kirjoitaan teksti, niin viereeseen soluun tulee tätä tekstiä vastaava kuva. Nuo kuvat on liitetty Exceliin toiselle välilehdelle, nyt ne vaan pitäisi saada näkymään tekstin vieressä.

11

1444

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • nyt Sheet1 solua C10 käytetään ja kuvat taulukossa Sheet2.

      taulukon moduuliin...

      Private Sub Worksheet_Change(ByVal Target As Range)
      Dim Kuva As Picture
      Dim Kuva2 As Picture
      If Not Intersect(Target, Range("C10")) Is Nothing Then
      For Each Kuva In Sheets("Sheet1").Pictures
      If Kuva.Top = Target.Offset(0, 1).Top And Kuva.Left = Target.Offset(0, 1).Left Then
      Kuva.Delete
      End If
      Next
      With Target
      For Each Kuva2 In Sheets("Sheet2").Pictures
      If Kuva2.Name = .Text Then
      Sheets("Sheet2").Shapes(Kuva2.Name).Copy
      ActiveSheet.Paste
      Selection.Top = .Offset(0, 1).Top
      Selection.Left = .Offset(0, 1).Left
      ' Selection.Height = 200
      ' Selection.Width = 200
      Exit For
      End If
      Next Kuva2
      End With
      End If
      End Sub

      Keep Excelling
      @Kunde

      • Excel-Turo

        Kiitoksia paljon tästä Kunde. Voisitko vähän vielä neuvoa tarkemmin kuinka tämä tehdään, olen sen verran aloittelija excelin kanssa. VBA:n kanssa perusasiatkin ovat opettelussa.

        Eli sheet1 solussa C10 syötetään tuo hakuteksti, jota vastaava kuva sitten pitäisi hakea sheet2 välilehdeltä vaikka sheet1 soluun c11. Kuinka saan nimettyä nuo kuvat sheet2 välilehdellä? Pitääkö sheet1 lisätä hakunappi, johon makro jossa tuo koodi minkä lähetit? Vai onnistuuko se niin, että kun sheet1 c10- solun tekstiä muutetaan, niin myös viereinen kuva muuttuu?


      • Excel-Turo kirjoitti:

        Kiitoksia paljon tästä Kunde. Voisitko vähän vielä neuvoa tarkemmin kuinka tämä tehdään, olen sen verran aloittelija excelin kanssa. VBA:n kanssa perusasiatkin ovat opettelussa.

        Eli sheet1 solussa C10 syötetään tuo hakuteksti, jota vastaava kuva sitten pitäisi hakea sheet2 välilehdeltä vaikka sheet1 soluun c11. Kuinka saan nimettyä nuo kuvat sheet2 välilehdellä? Pitääkö sheet1 lisätä hakunappi, johon makro jossa tuo koodi minkä lähetit? Vai onnistuuko se niin, että kun sheet1 c10- solun tekstiä muutetaan, niin myös viereinen kuva muuttuu?

        Kuvan nimeäminen:
        Klikkaa kuvaa ja nimiruudussa kirjoitat haluamasi nimen ja ENTER

        ei tartte nappia, kun nimi muuttuu niin hakee automaattisesti (jos soluun kirjoitetaan nimetty kuva löytyy kuvista)...

        toki voit tehdä kuvista listan ja laittaa sen kelpoissusehdoksi niin ainakin menee oikein( nimi on Case Sensitive) eli pitää olla just oikein kirjoitettu tai sitten koodissa muutat esim.
        If Ucase(Kuva2.Name) =Ucase( .Text) Then jolloin isoilla ja pienillä kirjaimilla ei ole eroa

        Keep Excelling
        @Kunde


      • kuvanvaihtaja
        kunde kirjoitti:

        Kuvan nimeäminen:
        Klikkaa kuvaa ja nimiruudussa kirjoitat haluamasi nimen ja ENTER

        ei tartte nappia, kun nimi muuttuu niin hakee automaattisesti (jos soluun kirjoitetaan nimetty kuva löytyy kuvista)...

        toki voit tehdä kuvista listan ja laittaa sen kelpoissusehdoksi niin ainakin menee oikein( nimi on Case Sensitive) eli pitää olla just oikein kirjoitettu tai sitten koodissa muutat esim.
        If Ucase(Kuva2.Name) =Ucase( .Text) Then jolloin isoilla ja pienillä kirjaimilla ei ole eroa

        Keep Excelling
        @Kunde

        näin:
        Kuvien nimet ja kuvat Taul2 A ja B sarakkeella (otsikkoineen)
        Tehdään kerralla dynaaminen taulukko (hakukaavat päivittyy automaattisesti sitä mukaa kun lisäät uusia nimiä ja kuvia)
        1. Taul2 A1 otsikko "Nimi" ja B1 "Kuva" (Otsikot saat tietysti itse valita)
        - A2 kuvan nimi, B2 kuva (isonnat solun kokoa että kuva varmasti sopii solun sisälle)
        - jne...
        2. Klikkaa Lisää > Nimi > Määritä
        - "Nimet työkirjassa" anna nimi vaikka: Nimilista
        - "Viittaa" kohtaan =SIIRTYMÄ(Taul2!$A$1;1;0;LASKE.A(Taul2!$A:$A)-1;1)
        - Uusi "Nimet työkirjassa" anna nimi: Kuvat
        - "Viittaa" kohtaan =SIIRTYMÄ(Taul2!$B$2;VASTINE(Taul1!$A$2;Nimilista;0)-1;0;1;1)
        3.Klikkaa Taul1 A2 (tämän voit määrätä itse, mutta muista laittaa sama kaavaan kohtaan ...VASTINE(Taul1!$A$2....)
        - avaa Tiedot > Kelpoisuustarkistus
        - Asetukset-välilehti: "Hyväksy" --> Luettelo
        - Lähde: =Nimilista
        4. Mene Taul2 ja klikkaa 1 kuvaa ja Kopioi
        - mene Taul1 ja Liitä (kuvan voi liittää minne vain, ei tarvitse mitään määrättyä solua, eikä ole solun koosta riippuvainen, on ns. "kelluva" kuva ja kokoa voi "kahvoista" isontaa/pinentää)
        - klikkaa ylhäältä Kaavariviä kuvan ollessa vielä "valittuna" ja kirjoita sinne =Kuvat
        Klikkaa nyt A2, nuolta painamalla avautuu "Nimilista", valitse joku ja kuva vaihtuu
        Voit lisätä Taul2 A ja B sarakkeelle uusia nimiä ja kuvia, "Nimilista" ja "Kuvat" päivittyy mukana automaattisesti, ei tarvitse muuttaa kaavoihin alueita
        Voit tietenkin jättää tuon "Kelpoisuustarkistuksen" pois ja kirjoittaa suoraan A2:selle nimen, mutta muista että nimi täytyy olla aivan samaten kirjoitettu kuin se on Taul2:ssa kirjoitettu, muuten ei löydy
        Näyttää hankalalta mutta kun perehtyy niin on ihan "simppeli" juttu.


      • Excel-Turo
        kuvanvaihtaja kirjoitti:

        näin:
        Kuvien nimet ja kuvat Taul2 A ja B sarakkeella (otsikkoineen)
        Tehdään kerralla dynaaminen taulukko (hakukaavat päivittyy automaattisesti sitä mukaa kun lisäät uusia nimiä ja kuvia)
        1. Taul2 A1 otsikko "Nimi" ja B1 "Kuva" (Otsikot saat tietysti itse valita)
        - A2 kuvan nimi, B2 kuva (isonnat solun kokoa että kuva varmasti sopii solun sisälle)
        - jne...
        2. Klikkaa Lisää > Nimi > Määritä
        - "Nimet työkirjassa" anna nimi vaikka: Nimilista
        - "Viittaa" kohtaan =SIIRTYMÄ(Taul2!$A$1;1;0;LASKE.A(Taul2!$A:$A)-1;1)
        - Uusi "Nimet työkirjassa" anna nimi: Kuvat
        - "Viittaa" kohtaan =SIIRTYMÄ(Taul2!$B$2;VASTINE(Taul1!$A$2;Nimilista;0)-1;0;1;1)
        3.Klikkaa Taul1 A2 (tämän voit määrätä itse, mutta muista laittaa sama kaavaan kohtaan ...VASTINE(Taul1!$A$2....)
        - avaa Tiedot > Kelpoisuustarkistus
        - Asetukset-välilehti: "Hyväksy" --> Luettelo
        - Lähde: =Nimilista
        4. Mene Taul2 ja klikkaa 1 kuvaa ja Kopioi
        - mene Taul1 ja Liitä (kuvan voi liittää minne vain, ei tarvitse mitään määrättyä solua, eikä ole solun koosta riippuvainen, on ns. "kelluva" kuva ja kokoa voi "kahvoista" isontaa/pinentää)
        - klikkaa ylhäältä Kaavariviä kuvan ollessa vielä "valittuna" ja kirjoita sinne =Kuvat
        Klikkaa nyt A2, nuolta painamalla avautuu "Nimilista", valitse joku ja kuva vaihtuu
        Voit lisätä Taul2 A ja B sarakkeelle uusia nimiä ja kuvia, "Nimilista" ja "Kuvat" päivittyy mukana automaattisesti, ei tarvitse muuttaa kaavoihin alueita
        Voit tietenkin jättää tuon "Kelpoisuustarkistuksen" pois ja kirjoittaa suoraan A2:selle nimen, mutta muista että nimi täytyy olla aivan samaten kirjoitettu kuin se on Taul2:ssa kirjoitettu, muuten ei löydy
        Näyttää hankalalta mutta kun perehtyy niin on ihan "simppeli" juttu.

        Kiitoksia molemmille vastanneille. Kokeilin tuota jälkimmäistä vaihtoehtoa ja homma onnistui tuohon kohtaan 4 asti. Kun kuva 1 on kopioitu TAUL1een ja on vielä valittuna, niin kaavariville kirjoittaminen ei onnistu. Mikähän tuossa menee pieleen?


      • Ei nörtti
        kuvanvaihtaja kirjoitti:

        näin:
        Kuvien nimet ja kuvat Taul2 A ja B sarakkeella (otsikkoineen)
        Tehdään kerralla dynaaminen taulukko (hakukaavat päivittyy automaattisesti sitä mukaa kun lisäät uusia nimiä ja kuvia)
        1. Taul2 A1 otsikko "Nimi" ja B1 "Kuva" (Otsikot saat tietysti itse valita)
        - A2 kuvan nimi, B2 kuva (isonnat solun kokoa että kuva varmasti sopii solun sisälle)
        - jne...
        2. Klikkaa Lisää > Nimi > Määritä
        - "Nimet työkirjassa" anna nimi vaikka: Nimilista
        - "Viittaa" kohtaan =SIIRTYMÄ(Taul2!$A$1;1;0;LASKE.A(Taul2!$A:$A)-1;1)
        - Uusi "Nimet työkirjassa" anna nimi: Kuvat
        - "Viittaa" kohtaan =SIIRTYMÄ(Taul2!$B$2;VASTINE(Taul1!$A$2;Nimilista;0)-1;0;1;1)
        3.Klikkaa Taul1 A2 (tämän voit määrätä itse, mutta muista laittaa sama kaavaan kohtaan ...VASTINE(Taul1!$A$2....)
        - avaa Tiedot > Kelpoisuustarkistus
        - Asetukset-välilehti: "Hyväksy" --> Luettelo
        - Lähde: =Nimilista
        4. Mene Taul2 ja klikkaa 1 kuvaa ja Kopioi
        - mene Taul1 ja Liitä (kuvan voi liittää minne vain, ei tarvitse mitään määrättyä solua, eikä ole solun koosta riippuvainen, on ns. "kelluva" kuva ja kokoa voi "kahvoista" isontaa/pinentää)
        - klikkaa ylhäältä Kaavariviä kuvan ollessa vielä "valittuna" ja kirjoita sinne =Kuvat
        Klikkaa nyt A2, nuolta painamalla avautuu "Nimilista", valitse joku ja kuva vaihtuu
        Voit lisätä Taul2 A ja B sarakkeelle uusia nimiä ja kuvia, "Nimilista" ja "Kuvat" päivittyy mukana automaattisesti, ei tarvitse muuttaa kaavoihin alueita
        Voit tietenkin jättää tuon "Kelpoisuustarkistuksen" pois ja kirjoittaa suoraan A2:selle nimen, mutta muista että nimi täytyy olla aivan samaten kirjoitettu kuin se on Taul2:ssa kirjoitettu, muuten ei löydy
        Näyttää hankalalta mutta kun perehtyy niin on ihan "simppeli" juttu.

        puoli tuntia väsäsin 20 vuoden Excel kokemuksella...
        kumpi sitten käyttäjän kannalta helpompaa?
        lisätä kuvat mihin vaan taulukossa2, nimetä ne sopivalla nimellä ohjeiden mukaan ja kopioida Kunden koodi ja se on siinä...
        vaiko tuhertaa?
        päättäkää itse ;- )


      • Excel-Turo
        Ei nörtti kirjoitti:

        puoli tuntia väsäsin 20 vuoden Excel kokemuksella...
        kumpi sitten käyttäjän kannalta helpompaa?
        lisätä kuvat mihin vaan taulukossa2, nimetä ne sopivalla nimellä ohjeiden mukaan ja kopioida Kunden koodi ja se on siinä...
        vaiko tuhertaa?
        päättäkää itse ;- )

        No nyt sain toimimaan sen Kunden ohjeen / koodin avulla. Vielä kun tuon saisi niin, että tuon kuvan pystyisi kopiomaan useammalle välilehdelle tiettyihin soluihin. Eli ensimmäisellä sivulla on tuo valintatekstisolu ja kuva kopioituisi valituille välilehdille valittuun soluun.


      • Excel-Turo kirjoitti:

        No nyt sain toimimaan sen Kunden ohjeen / koodin avulla. Vielä kun tuon saisi niin, että tuon kuvan pystyisi kopiomaan useammalle välilehdelle tiettyihin soluihin. Eli ensimmäisellä sivulla on tuo valintatekstisolu ja kuva kopioituisi valituille välilehdille valittuun soluun.

        helpostikin fiksattua kuten ei nörtti toteaa kopioimalla....

        Private Sub Worksheet_Change(ByVal Target As Range)
        Dim Kuva As Picture
        Dim Kuva1 As Picture
        Dim Kuva2 As Picture
        Dim Kuva3 As Picture
        'jne
        On Error Resume Next
        If Not Intersect(Target, Range("C10")) Is Nothing Then
        For Each Kuva1 In Sheets("Taul1").Pictures
        If Kuva1.Top = Target.Offset(0, 1).Top And Kuva1.Left = Target.Offset(0, 1).Left Then
        Kuva.Delete
        End If
        Next Kuva1

        For Each Kuva2 In Sheets("Taul3").Pictures
        If Kuva2.Top = Target.Offset(0, 1).Top And Kuva2.Left = Target.Offset(0, 1).Left Then
        Kuva2.Delete
        End If
        Next Kuva2

        For Each Kuva3 In Sheets("Taul4").Pictures
        If Kuva3.Top = Target.Offset(0, 1).Top And Kuva3.Left = Target.Offset(0, 1).Left Then
        Kuva3.Delete
        End If
        Next Kuva3
        'jne

        With Target
        For Each Kuva In Sheets("Taul2").Pictures
        If Kuva.Name = .Text Then
        Sheets("Taul2").Shapes(Kuva.Name).Copy

        Sheets("Taul1").Activate
        ActiveSheet.Paste
        Selection.Top = .Offset(0, 1).Top
        Selection.Left = .Offset(0, 1).Left

        Sheets("Taul3").Activate
        ActiveSheet.Paste
        Selection.Top = Range("F10").Top
        Selection.Left = Range("F10").Left

        Sheets("Taul4").Activate
        ActiveSheet.Paste
        Selection.Top = Range("C4").Top
        Selection.Left = Range("C4").Left
        Exit For
        End If
        Next Kuva
        End With
        End If
        End Sub


      • kuvanvaihtaja
        kunde kirjoitti:

        helpostikin fiksattua kuten ei nörtti toteaa kopioimalla....

        Private Sub Worksheet_Change(ByVal Target As Range)
        Dim Kuva As Picture
        Dim Kuva1 As Picture
        Dim Kuva2 As Picture
        Dim Kuva3 As Picture
        'jne
        On Error Resume Next
        If Not Intersect(Target, Range("C10")) Is Nothing Then
        For Each Kuva1 In Sheets("Taul1").Pictures
        If Kuva1.Top = Target.Offset(0, 1).Top And Kuva1.Left = Target.Offset(0, 1).Left Then
        Kuva.Delete
        End If
        Next Kuva1

        For Each Kuva2 In Sheets("Taul3").Pictures
        If Kuva2.Top = Target.Offset(0, 1).Top And Kuva2.Left = Target.Offset(0, 1).Left Then
        Kuva2.Delete
        End If
        Next Kuva2

        For Each Kuva3 In Sheets("Taul4").Pictures
        If Kuva3.Top = Target.Offset(0, 1).Top And Kuva3.Left = Target.Offset(0, 1).Left Then
        Kuva3.Delete
        End If
        Next Kuva3
        'jne

        With Target
        For Each Kuva In Sheets("Taul2").Pictures
        If Kuva.Name = .Text Then
        Sheets("Taul2").Shapes(Kuva.Name).Copy

        Sheets("Taul1").Activate
        ActiveSheet.Paste
        Selection.Top = .Offset(0, 1).Top
        Selection.Left = .Offset(0, 1).Left

        Sheets("Taul3").Activate
        ActiveSheet.Paste
        Selection.Top = Range("F10").Top
        Selection.Left = Range("F10").Left

        Sheets("Taul4").Activate
        ActiveSheet.Paste
        Selection.Top = Range("C4").Top
        Selection.Left = Range("C4").Left
        Exit For
        End If
        Next Kuva
        End With
        End If
        End Sub

        kirjoittajalta. Epäilin ensin että kaavoihin oli tullut joku "painovirhepaholainen"
        ja testasin ne suoraan tuosta kopioimalla, kyllä ne pelasi.
        Ensin ei meinannut vaihtaa kuvaa ollenkaan, mutta sitten "otin" hiirellä kiinni tuosta A2 ja siirsin sen eri paikkaan, niin heti alkoi pelaamaan. En tiedä mikä siinä oli.
        Käytössä Excel 2003


      • kuvanvaihtaja
        kuvanvaihtaja kirjoitti:

        kirjoittajalta. Epäilin ensin että kaavoihin oli tullut joku "painovirhepaholainen"
        ja testasin ne suoraan tuosta kopioimalla, kyllä ne pelasi.
        Ensin ei meinannut vaihtaa kuvaa ollenkaan, mutta sitten "otin" hiirellä kiinni tuosta A2 ja siirsin sen eri paikkaan, niin heti alkoi pelaamaan. En tiedä mikä siinä oli.
        Käytössä Excel 2003

        mainitsematta tuo sivu josta itse aikanaan sain ohjeet tuon "tempun" tekemiseen.
        http://www.jkp-ads.com/articles/ShowPicture00.asp


      • Excel-Turo

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

    Luetuimmat keskustelut

    1. Anna minulle anteeksi

      Anna minulle anteeksi. Minä pyydän.
      Ikävä
      157
      2507
    2. Kun viimeksi kohtasitte/näitte

      Mitä olitte tekemässä? Millainen ympäristö oli? Löydetään toisemme...
      Ikävä
      134
      1935
    3. Olet kyllä vaarallisen himokas

      Luova, kaunis, määrätietoinen, pervo, mielenkiintoinen, kovanaama, naisellinen ja erikoinen.
      Ikävä
      106
      1785
    4. Mikä on hän on ammatiltaan?

      Vai tiedätkö mitä kaivattusi tekee työkseen?
      Ikävä
      72
      1460
    5. Mitä ajattelit silloin kun

      Löysit hänet?
      Ikävä
      76
      1398
    6. Anna vielä vähän vihreää valoa

      Teen sitten siirtoni, nainen. Tiedän, että olet jo varovaisesti yrittänyt lähestyä, mutta siitä on jo aikaa. Jos tunnet
      Ikävä
      21
      1357
    7. Syksyinen aamuketju suden

      Hyvää huomenta ja kaunista syyspäivää. 🌞🍁🍂☕
      Ikävä
      227
      1100
    8. Oletko tutustunut muihin

      Samalla tavalla kuin häneen?
      Ikävä
      71
      890
    9. Miksi homous puhuttaa konservatiiveja vuodesta toiseen?

      Kysymykseen on vastattukin Kansanlähetyksen osalta: "Miksi sukupuoleen ja seksuaalisuuteen liittyvät asiat ovat konserv
      Luterilaisuus
      220
      886
    10. Uskotko että kohdataan vielä?

      Kysymys otsikossa, aloitukseen ei muuta lisättävää.
      Ikävä
      54
      857
    Aihe