Minulla on yhdella taulukon sivulla sisällysluettelo.
Kun muutan tietoja sisällysluettelossa, tietojen pitäisi muuttua tietyillä välilehdillä samalla.
Olen toteuttanut tämän kopioimalla etusivun solun ja "liittämällä linkin" haluamaani kohaan toisella älilehdellä.
Homma toimiikin hyvin, mutta on todella työlästä tehdä pohja jokaiselle haluamalleni sivulle ja solulle erikseen.
Onko helpompaa tapaa?
Jos siis kirjoitan Taul1 (sisällysluettelosivu) soluun C12 "Kuusinen", taul128 solussa F33 muuttuisi sama teksti. Osaan tehdä tämän vain yksitellen, mutta uskoisin että on helpompiakin keinoja.
Kiitos.
Liitä inkki
4
238
Vastaukset
- kaarlo_kankkunen
Mikä taulukkolaskenta-ohjelma sulla on käytössä?
Itselläni on suomenkielinen Microsoft Excel 2010, ja siinä toi homma menee tälleen (mikäli käsitin kysymyksen oikein):
Kirjoita (ilman lainausmerkkejä) "=taul1!c12" kaikkiin niihin soluihin, joihin haluat taulukossa 1, solussa C12 olevan tekstin kopioituvan automaattisesti. - Toimistoveteraani
Kiitos! Aivan oikein ymmärsit ja neuvoit, tämä helpottaa jo huomattavasti.
Pystyykö saman hoitamaan vielä niin, että syöttäisi "koodeja" tuohon
sisällysluettelo sivulle ja tieto siirtyisi sinne muille välilehdille. Eli sama
homma ja lopputulos, mutta tehtäisiin tavallaan käänteisesti.- Tämmöinen
Soluun kirjoitettu tieto kumoaa siinä aiemmin olleen, mutta makrolla onnistuu.
Kun jotain muutetaan, makro tutkii onko muutettu solu listalla ja kirjoittaa saman tiedon sen pariksi merkittyyn. Tiedosto on talletettava makrot sallivassa muodossa .xlsm
Paina välilehden nimi-täppää hiiren oikealla ja valitse listalta "Näytä koodi" (tai jotain sen tapaista – en tiedä tarkaan, kun minulla ei ole suomennosta). Aukeaa VBA-editori ja kyseisen välilehden ohjelmamoduli. Kopioi alla oleva kolmen rivin makro tuohon ikkunaan. Kopioi se myös kaikkien muiden välilehtien vastaaviin moduleihin. Ne saa valittua joko edellä kuvatulla tavalla, tai VBA-editorista ruudun vasemmasta laidasta kohdasta Microsoft Excel Objektit ja ko. välilehden nimi.
Private Sub Worksheet_Change(ByVal Target As Range)
Päivitä (Target.Address)
End Sub
Tee yleinen ohjelmamoduli. Valitse VBA:ssa ylhäältä menuriviltä Lisää - Moduli. Kopioi siihen kaikki tästä alas päin. Huomaa, jos linkkejä muutetaan, ne ovat käytössä vasta kun Sub Alusta on ajettu - siirrä kursori sen kohdalle ja paina F5.
Const hakemisto = "Sheet1" ' Hakemisto-välilehden nimi
Const linkit = _
"Taul1!A1=Taul2!A1," & _
"Taul1!A2=Taul2!A2," & _
"Taul1!A3=Taul3!A1," & _
"Taul1!A4=Taul3!A2" ' Laita sopivat linkit
Const maksi = 3 ' kasvata tätä riittävästi
Dim alustettu As Boolean
Dim linkki(maksi, 1) As String
Sub Alusta()
Dim a() As String
Dim b() As String
Dim i
a = Split(linkit, ",")
For i = 0 To maksi
b = Split(a(i), "=")
linkki(i, 0) = b(0)
linkki(i, 1) = b(1)
Next i
alustettu = True
End Sub
Sub Päivitä(t As String)
Dim i, k, o
If Not alustettu Then Alusta
On Error GoTo Loppu:
k = 0: o = 1
If ActiveSheet.Name = hakemisto Then k = 1: o = 0
For i = 0 To maksi
If ActiveSheet.Name & "!" & WorksheetFunction.Substitute(t, "$", "") _
= linkki(i, o) Then Exit For
If i = maksi Then Exit Sub
Next i
Application.EnableEvents = False
Worksheets(Left(linkki(i, k), InStr(linkki(i, k), "!") - 1)) _
.Range(Mid(linkki(i, k), InStr(linkki(i, k), "!") 1, 10)) _
= Range(t).Value
Loppu:
Application.EnableEvents = True
End Sub
- Toimistoveteraani
Mahtavia ihmisiä täällä. Kiitos.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Jaaha, sitä on vasemmistoryhmä käynyt häiriköimässä Purran kodin vieressä
On näköjään iso lakana levitetty puiden väliin, jossa lukee mm. "Haista vi*** Riikka Purra". Tunkekaa leikkaukset pers..2316661Päivi Räsänen vs. Abbas Bahmanpour
(Bahmanpour on imaami Helsingissä) Syyttäjä siis jahtaa edelleen Räsästä tämän H-puheista, joissa hän on ilmeisesti vaa1125030Demokratian uhka: Perussuomalaiset ja polarisoiva "me ja muut" -ajattelu
Laurence Rees varoittaa, kuinka demokratian heikkeneminen ja autoritaaristen liikkeiden nousu voidaan liittää "me ja muu1564791"Rauhanomainen" miekkari hesassa: "Eläköön aseellinen vastarinta" - lakana
Kyseessä on Suomen Palestiinalaisten yhdistyksen viime perjantaina järjestämä ”Hiljainen kynttiläkulkue Palestiinalaiste633274Palkansaajan oikeus nauttia työuransa hedelmistä
Työeläkejärjestelmä on verrattavissa pyramidihuijaukseen, jossa alemmat tasot, eli nykyiset palkansaajat, toimivat maksa1052893En koskaan tule sinulle tätä kertomaan
Kun kirjoitin sinulle viimeisintä viestiä, huomasin kyynelten valuvan poskiani pitkin.652339Saatoin tehdä elämäni isoimman virheen
Otsikko kertoo kaiken. Miksei kaikki voi olla yksinkertaisempaa?1391900- 691884
odotatko vielä viestiä minulta...
Mies...? En tiedä mitä sanoa 😔 auta vähän naista ja tule enemmän vastaan1391734Onko rajojen kiinnipitäminen ihmisoikeuksien vastaista?
Maahanmuutosta puhutaan usein niin kuin kyse olisi vain numeroista ja rajoista. Kyse on kumminkin ihmisistä, jotka halua2231630