Teen VBA:lla paljon makroja. Nyt ongelmani on löytää sheet1 välilehdeltä ne rivit jotka täyttävät hakuarvon. En halua kirjata pitkiä koodia vaan tiedän, että se onnistuu muutamalla rivillä. Voisiko se olla jotain valitun alueen solut käydään läpi ja jos arvo löytyy niin rivi kopioidaan tiettyyn paikkaa ja tämä toistetaan niin monesti kun alue on testattu. Auttakaa jos tiedätte ratkaisun.
Jos olet excelissä hyvä tekemään apuohjelmia niin voitaisiin jakaa kokemuksia enemmälti.
Excelillä voi tehdä mitä vain!
VBA Excelissä
8
857
Vastaukset
- Nimimerkki
Nyt nopeasti, mutta palaan asiaan uudelleen:
> Voisiko se olla jotain valitun alueen solut käydään läpi ja jos arvo
> löytyy niin rivi kopioidaan tiettyyn paikkaa ja tämä toistetaan niin
> monesti kun alue on testattu. Auttakaa jos tiedätte ratkaisun.
Itse laittaisin nuo tiedot lista muotoon ( Tietikanta taulukko ), yhdelle taulukolle, ainakun tietoa syötetään tuohon taulukkoon lista järjestetään haluttuun järjestykseen.
sitten erikois suodatuksella suodatan näkyviin tuosta vain ne halutut tiedot.
Jos haluaisin muussa muodossa tiedot, tekisin oman pohjan toiseen taulukkoon ja makrolla kopoisin halutut tiedot tuolle toiselle taulukolle.
Tässä jokuaika sitten joku kysyi miten syötetään tieto ( Autoista ) suoraan haluttuun muotoon, mutta itse en käyttäisi sellaista mallia, koska jos haluat muita pohjia ja et voi kovin yksinkertaisesti pomia haluttuja tietoja jos tiedot ovat muussa muodossa kuin lista muodossa.
Aloitan uuden projektin ensi viikolla joss on tarkoitus pitää listaa asiakkaista ( yhdele taulukolle ) ja heihin kohdistuviin tapahtumiin ( toiselle taulukolle ). Tuosta pitää esimerkiksi tulostaa jonkun aisakkaan tiedot ja tapahtumat peräkkäin, toden näköisesti tehen pohjan tulostusta varten johon siirrän valitun asiakkaan tiedot ja tapahtumat.
En nyt rupea vääntään tuota makroa, mutta palataan asiaan.
> Jos olet excelissä hyvä tekemään apuohjelmia niin voitaisiin
> jakaa kokemuksia enemmälti.
Juuri siksi ole täällä, itse en niin hyvä ole mutta kokemuksia otan vastaan ja yritän vähän kirjoitella, vaikka tuo kirjallinen ilmaisu aika huonoa ja hidasta onkin.
> Excelillä voi tehdä mitä vain!
Kyllä ehdottomasti, mutta excelin ongelma on se että asioita voi tehdä niinn monella eri tavalla että tahtoo mennä sekaisin mikä on oikein kuhunkin tilanteeseen, ja kun oppii koko aja uutta niin toiseta päästä jo tahtoo unohtua toisia asioita. Siksi suosittenen että jo suunnittelu vaiheessa luo joitakin sääntöja joita sitten noudattaa niin kauan kuin mahdollista, näin monimutkainenkin projeksti pysyy edes jollakin tavalla kasassa, esim minulla Tiedot listaan omaan taulukkoon, tulostus omaan taulukkonn, sivun ylä laitaan rivit 1-15 mahdolliset toiminta napit ja makrot jne..... tossapa sulle makro, jolla kikkailemalla voi sitten tehdä mitä vaan, koska se palauttaa Rangen...
nyt hakee 1000 sarakkeista A:D ja kopioi rivit Taul2 sarakkeeseen A ensimmäistä tyhjästä solusta alkaen
Union funktiota joutuu käyttään sen takia, koska luku voi löytyä useammasta sarakkeesta ja tällöin alueet leikkaavat ja antaa virheilmoituksen- tolla siis korjataan tuo...
moduuliin...
Function LaajennettuHaku(Hakuehto As Variant, _
Hakualue As Range, _
Optional Mitä As Variant, _
Optional Miten As Variant, _
Optional Kokosolu As Boolean) As Range
Dim solu As Range
Dim Eka As String
If IsMissing(Mitä) Then Mitä = xlValues
If IsMissing(Miten) Then Miten = xlPart
If IsMissing(Kokosolu) Then Kokosolu = False
With Hakualue
Set solu = .Find( _
What:=Hakuehto, _
LookIn:=Mitä, _
LookAt:=Miten, _
SearchOrder:=xlByRows, _
SearchDirection:=xlNext, _
MatchCase:=Kokosolu, _
SearchFormat:=False)
If Not solu Is Nothing Then
Set LaajennettuHaku = solu
Eka = solu.Address
Do
Set LaajennettuHaku = Union(LaajennettuHaku, solu)
Set solu = .FindNext(solu)
Loop While Not solu Is Nothing And solu.Address Eka
End If
End With
End Function
Sub Testi()
On Error GoTo virhe:
Dim löydetty As Range
Set löydetty = LaajennettuHaku(1000, Columns("A:D"), xlValues, xlPart, False).EntireRow
Union(löydetty, löydetty).Copy Range("Taul2!A65536").End(xlUp).Offset(1, 0).EntireRow
Exit Sub
virhe:
MsgBox "Hakuehdollasi ei löytynyt yhtään tietuetta!"
End Sub
Keep Excelling- Excel is fun
Kiitos tästä koodista. Sairaan hyvä juttu. Tunnut osaavan Exceliä aika hyvin.
PALATAAN AIHEESEEN
Excel is FUN - ei löydä kaikkea
Tämä esimerkki on minullekin tarpeellinen, mutta jotain hämärää tässä taitaa olla. Muokkasin yhden rivin seuraavaksi:
Set löydetty = LaajennettuHaku("x", Columns("m:m"), xlValues, xlPart, False).EntireRow
X:n tilalla kokeilin aakkosia ja numerot 0-9. Muut hakuehdot toimivat, mutta ei kirjaimet c, d, e, i, n, o, p, q, r, s ja t, vaan niillä tulee aina tuo virheilmoitus. Sarakkeesta kuitenkin oikeasti löytyy noitakin merkkejä. Mistähän tuo ongelma johtuu? Käytössä on siis excelin versio 2003.
(saa nähdä nostaako S24 nämä vanhoihin viesteihin vastaukset listalla ylös, vai jääkö edelleen tänne "piiloon")
ainakin mulla toimii 2003 versiossa tää
Sub Testi()
On Error GoTo virhe:
Dim löydetty As Range
Set löydetty = EtsiJaSiirrä("d", Columns("m:m")).EntireRow
Union(löydetty, löydetty).Copy Range("Sheet2!A65536").End(xlUp).Offset(1, 0).EntireRow
Exit Sub
virhe:
MsgBox "Hakuehdollasi ei löytynyt yhtään tietuetta!"
End Sub
Function EtsiJaSiirrä(Hakuehto As Variant, HakuAlue As Range) As Range
Dim solu As Range
Dim EkaOsoite As String
Worksheets("Sheet1").Activate
With HakuAlue
Set solu = .Find( _
What:=Hakuehto, _
LookIn:=xlValues, _
LookAt:=xlWhole, _
SearchOrder:=xlByRows, _
SearchDirection:=xlNext, _
MatchCase:=False, _
SearchFormat:=False)
If Not solu Is Nothing Then
Set EtsiJaSiirrä = solu
EkaOsoite = solu.Address
Do
Set EtsiJaSiirrä = Union(EtsiJaSiirrä, solu)
Set solu = .FindNext(solu)
Loop While Not solu Is Nothing And solu.Address EkaOsoite
End If
End With
End Function- ei vieläkään
Kiitos vastauksesta. Tuo uusikaan versio ei kyllä jostain syystä toimi tällä koneella (tai käyttäjällä). Mikään muu haku ei näytä tuottavan tulosta kuin *-merkki, joka tietysti kopioi kaikki ei-tyhjät solut.
Edellinen esimerkki toimii siis minulla paremmin, mutta en ole vielä päässyt selville, että miksi vain osaa kirjaimista voi hakea. Tällä koneella on käytössä enkunkielinen Excel 2003 (11.8332.8333). ei vieläkään kirjoitti:
Kiitos vastauksesta. Tuo uusikaan versio ei kyllä jostain syystä toimi tällä koneella (tai käyttäjällä). Mikään muu haku ei näytä tuottavan tulosta kuin *-merkki, joka tietysti kopioi kaikki ei-tyhjät solut.
Edellinen esimerkki toimii siis minulla paremmin, mutta en ole vielä päässyt selville, että miksi vain osaa kirjaimista voi hakea. Tällä koneella on käytössä enkunkielinen Excel 2003 (11.8332.8333).sama enkkuversio mullakin, mutta SP3 lisäksi.
Todella outoa on toi "ei toimivuus" - ei muuten toiminut mullakaan enää toi ekaversio???
Muokkasin ton jälkimmäisen siitä ja se toimii ihan jees- toimii jossain
kunde kirjoitti:
sama enkkuversio mullakin, mutta SP3 lisäksi.
Todella outoa on toi "ei toimivuus" - ei muuten toiminut mullakaan enää toi ekaversio???
Muokkasin ton jälkimmäisen siitä ja se toimii ihan jeesJoo, mullakin on siis SP3 asennettuna. Esimerkkisi toimii loistavasti kotikoneessani, jossa on suomiversio 2007 (SP2). Ei nyt oikein hahmota, että miksi toisen koneen vanhemmassa versiossa toimii niin oudosti. Pitää testailla lisää, kunhan ehtii.
Jotain muuta saattaa hyödyttää, joten alla uudempi esimerkkisi hieman muokattuna (helpottaa ainakin itselläni vähän testaamista, varsinkin kun tuon liittää nappiin), ja tämä siis toimii aivan kuten on tarkoituskin:
Sub Testi()
On Error GoTo virhe:
Dim löydetty As Range
Merkki = InputBox("Anna haettava merkkijono", "Haku")
Sarake = InputBox("Anna sarake, josta haetaan", "Sarake")
Set löydetty = EtsiJaSiirrä(Merkki, Columns(Sarake)).EntireRow
Union(löydetty, löydetty).Copy Range("Taul2!A65536").End(xlUp).Offset(1, 0).EntireRow
Exit Sub
virhe:
MsgBox "Hakuehdollasi ei löytynyt yhtään tietuetta!"
End Sub
Function EtsiJaSiirrä(Hakuehto As Variant, HakuAlue As Range) As Range
Dim solu As Range
Dim EkaOsoite As String
Worksheets("Taul1").Activate
With HakuAlue
Set solu = .Find( _
What:=Hakuehto, _
LookIn:=xlValues, _
LookAt:=xlWhole, _
SearchOrder:=xlByRows, _
SearchDirection:=xlNext, _
MatchCase:=False, _
SearchFormat:=False)
If Not solu Is Nothing Then
Set EtsiJaSiirrä = solu
EkaOsoite = solu.Address
Do
Set EtsiJaSiirrä = Union(EtsiJaSiirrä, solu)
Set solu = .FindNext(solu)
Loop While Not solu Is Nothing And solu.Address EkaOsoite
End If
End With
Worksheets("Taul2").Activate
End Function
Ketjusta on poistettu 1 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Kuka oli töllöntyön tekijä?
Ketä on nyt pidätetty? Oliko syy mustasukkaisuus tyttöystävästä tai oliko muita lieventäviä seikkoja? Katuuko tekijä nyt333194Kotikasvatus siitä se lähtee eli missä meni vikaan että lapsesta tuli puukottaja
Ottakaa muut oppia, normaali kotielämä. Ei liikaa edes hengellisyyttä.441599Kun kohtaat jotain ainutlaatuista
ja upeaa, johon rakastut ehkä ensimmäistä kertaa ihan tosissaan. Sitten sähläät kaiken omien epävarmuuksien vuoksi. Eikö19991Mua ahdistaa
Tämä juttu. Miksi nainen torjuit minut vaikka kiinnostuksen merkkejä oli? Eihän tämän jutun olisi tarvinut johtaa sen pi32979- 59943
Ei tämä enää tervettä oo
Sydän pamppaillen oon jo tunnin meinannu laittaa sulle viestiä... Sormi tärisee lähetä kuvakkeen kohdalla.22938Tuli vain mieleen
että etkös sä yritäkin muiden miehiä? Se sun tuttava kertoi. En arvosta tuollaista naista, ihmekös kun oot sinkku. m -37850Perämoottoreiden huolto melkoisen kallista
Minulla on tuollainen keskikokoinen perämoottori ja yleistä merkkiä. Kyselin sille keväthuoltoa paikallisista liikkeistä36813Tanskademarit: ilman risusavottaa ei rahaa!
Näin persuna on pakko ihailla noita Tanskan demareita. Tanskalaisessa sosiaalidemokratiassa ei työtön saa rahaa ellei os173803- 48719