Kun excelissä on tuoterakenne, jossa on tuotenumero, ja tämä tuote pitää sisällää useita tuotteita. Nämä ovat kahdessa sarakkeessa, ja järjestelmä antaa jokaisen rakenneosan eteen myös tuotenumeron, eli näin:
11 12
11 13
11 14
22 23
22 24
22 25
Jossa siis tuotenumero on 11, ja se sisältää osat 12, 13 ja 14. Seuraava tuotenumero on 22, joka sisältää osat 23, 24 ja 25.
Nyt tämä tuhansien rivien setti pitäisi saada muotoon, että tuotenumero esiintyy vain kerran ja sen perässä siihen liittyvät osat, eli
11 12 13 14
Jokainen omassa sarakkeessa. Millä ihmeen kaavalla tämä onnistuisi?? Auttakaa gurut neitoa hädässä.
Tuoterakennekaava...tuskaa
6
525
Vastaukset
- Nimimerkki
Siis tuo lista on taulukko Osista, jos sinulla ei ole erikseen taulukkoa Tuotteista, siis jokainen tuote vain kerran, niin tehe sellainen vaikka "Erikoissuodatuksella", ja vain ainutkertaiset tietueet. laita nämä tuotteet omalle taulukolle ja osat omalle taulukolle, näin on myös parempi jatkossa niin voit ideoida enemmän uusia ominaisuuksia myöhemmin( suodatus, lisää tuote, lisää osa, listaa tuote, listaa vain tuotteen osat jne....)
http://office.microsoft.com/fi-fi/excel/HP030734251035.aspx?pid=CH062527971035
Uusi taulukko (tästä eteen päin sheet2)
Valitse uudesta taulukosta solu mihin haluat tuotteet
Valitse Tiedot-valikosta Suodata ja valitse sitten Erikoissuodatus.
Merkka alue sarakkeesta jossa on tuotteen numerot (valitse myös otsikko mukaan)
valitse Kopioi toiseen paikkaan. Kirjoita sitten soluviittaus Kopioi-ruutuun.
Valitse Vain ainutkertaiset tietueet -valintaruutu.
Nyt kun sinulla on lista Tuotteista, vain yksi ilmentymä per tuote, voi laittaa kaavan ( oletuksena nyt A-Sarake), laita B-sarakkeeseen seuraava kaava:
=IF($A7INDEX(Sheet1!$B:$C;MATCH($A7;Sheet1!$B:$B;0) COLUMN()-COLUMN($B:$B);1);"";INDEX(Sheet1!$B:$C;MATCH($A7;Sheet1!$B:$B;0) COLUMN()-COLUMN($B:$B);2))
Laitoin tuohon kaavaan dollari merkit jotta voit kopioida kaavan sekä alas että sivulle tarpeen mukaan.
jos haluat voin selittää myöhemmin kun kerkeän mitä tuossa kaavasssa on, testasin tuon pienellä testi taulukolla ja toimi ainakin minulla- Nimimerkki
siis kaavassa noi Osat ovat taulukossa "Sheet1", tuossa taulukossa tuote numerot sarakkeessa B ja osanumerot sarakkeessa C
katso miten sinulla on, ja muuta tarpeen mukaan
voisi tietenkin nimetä noi sarakkeet ja käyttää tuota nimeä kaavassa, mutta sehän onkin sitten toinen juttu - Nimimerkki
edellinen kaava nimiä käyttäen:
=IF($A7INDEX(Sheet1!$B:$C;MATCH($A7;Sheet1!$B:$B;0) COLUMN()-COLUMN($B:$B);1);"";INDEX(Sheet1!$B:$C;MATCH($A7;Sheet1!$B:$B;0) COLUMN()-COLUMN($B:$B);2))
muotoon
=IF($A7INDEX(osatTuotteenNroJaOsanNro;MATCH($A7;osatTuotteenNro;0) COLUMN()-COLUMN(tuotteetEkanOsanSarake);1);"";INDEX(osatTuotteenNroJaOsanNro;MATCH($A7;osatTuotteenNro;0) COLUMN()-COLUMN(tuotteetEkanOsanSarake);2))
Jossa
osatTuotteenNroJaOsanNro = taulukko jossa osat ja sarakkeet jossa on tuotteen numerot ja osien nro ( eli olisiko sarakkeet A ja B)
osatTuotteenNro = taulukko jossa osat ja sarake jossa on tuotteen nro ( olisiko sarake A)
tuotteetEkanOsanSarake = taulukko jossa on tuotteet ja sarake johon laitat ekan osan numeron ( olisiko sarake B tai C ) - Sanneliini
Nimimerkki kirjoitti:
edellinen kaava nimiä käyttäen:
=IF($A7INDEX(Sheet1!$B:$C;MATCH($A7;Sheet1!$B:$B;0) COLUMN()-COLUMN($B:$B);1);"";INDEX(Sheet1!$B:$C;MATCH($A7;Sheet1!$B:$B;0) COLUMN()-COLUMN($B:$B);2))
muotoon
=IF($A7INDEX(osatTuotteenNroJaOsanNro;MATCH($A7;osatTuotteenNro;0) COLUMN()-COLUMN(tuotteetEkanOsanSarake);1);"";INDEX(osatTuotteenNroJaOsanNro;MATCH($A7;osatTuotteenNro;0) COLUMN()-COLUMN(tuotteetEkanOsanSarake);2))
Jossa
osatTuotteenNroJaOsanNro = taulukko jossa osat ja sarakkeet jossa on tuotteen numerot ja osien nro ( eli olisiko sarakkeet A ja B)
osatTuotteenNro = taulukko jossa osat ja sarake jossa on tuotteen nro ( olisiko sarake A)
tuotteetEkanOsanSarake = taulukko jossa on tuotteet ja sarake johon laitat ekan osan numeron ( olisiko sarake B tai C )Heips ja kiitos vinkeistä. Alan tänään työstämään exceliä että josko se siitä oikenisi :-)
tekee just sen mitä pyytelet
moduuliin...
Sub KopioiPoista()
Dim vika As Integer
Dim vika2 As Integer
Dim vika3 As Integer
Dim i As Integer
On Error Resume Next
vika = Range("A65536").End(xlUp).Row
For i = vika To 1 Step -1
If i = 1 Then Exit Sub
If Range("A" & i) = Range("A" & i).Offset(-1, 0) Then
vika2 = Range("A" & i).End(xlToRight).Column
vika3 = Range("A" & i).Offset(-1, 0).End(xlToRight).Column
Range("B" & i).Resize(1, vika2 - 1).Copy Destination:=Range("A" & i).Offset(-1, vika3)
Range("A" & i).EntireRow.Delete
End If
Next
End Sub- Nimimerkki
Älä käytä tätä ellei sinulla ole muita tietoja kun nuo tuote nro ja osien nro.
jos sinulla on esim muita tietoja per osa ( mitat, koko, hinta, varasto, kuvia, jne...) joudut kuseen tuon kanssa. ja jos myöhemmin haluat lisää tietoja per osat joudut taas hajoittaan taulukon osiin. jos haluat muita tietoja osille käytä omaa taulukkoa tuotteille ja omaa taulukkoa osille.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Persujen vaalilupaus oli euron bensa
Nyt puhutaan jo kolmen euron bensasta. Kyseessä on Suomen historian törkein vaalipetos.922147Vain vasemmistohallitus saa minut menemään töihin
Änkyräkapitalistien sortaessa kansaa en laita rikkaakaan ristiin. Elän mielummin Kelan tuilla, ja jos niitä leikataan, n422105Maataloustuet perittävä korkojen kera takaisin
Yrittäjiltä jotka ovat myyneet tuotantoaan ulkomaille. Veronmaksajan kustantama tuki on tarkoitettu elintarvikkeiden hi501845Topi osti Askon
Hieno mies. Pelastaa työpaikkoja. Kiitokset myös emännälleen, joka pitää isännän virkeänä. https://www.is.fi/taloussan751370- 861261
Kastaa ja upottaa on eri sanat
Kastaa ja upottaa on eri sanat ja niillä on eri merkitys. Eikä Jeesusta haudattu upottamalla maahan kaivettuun kuoppaan2191151Uskomatonta touhua!
Ei olis uskonut että kateus yrittäjää kohtaan menee noin pitkälle. TTP:ssa irrotettu sähköjohto jäätelöaltaasta. Kaikki311080Oliko se oikeasti epäselvää
sinulle että olin ihastunut sinuun? (Ymmärrän että siitä on aikaa, eikä voi olettaa että kaikkea muistaisi tai että men561023- 67946
Miksi eduskuntatalon portaille sytyttään tänään 8 645 kynttilää?
Oikeus elämään ry järjestää lauantaina 21.3.2026 tapahtuman, jossa Eduskuntatalon portaille sytytetään 8 645 kynttilää.285910