[OO calc 3.2] automatisch invullen

Pagina: 1
Acties:

Onderwerpen


Acties:
  • 0 Henk 'm!

  • Punkie
  • Registratie: Oktober 2005
  • Laatst online: 26-04 20:11
Probleembeschrijving
De waarde van het veld "prijs" moet worden aangepast aan de hand van de waarde van een ander veld "CPU". De koppeling tussen de waarden voor velden CPU en prijs staat beschreven in een tabel:
code:
1
2
3
4
  CPU          prijs
   i750         175
   Q8800        331
   X3           12

In een andere tabel voeren we gegevens in. Wanneer we veld CPU invullen met vb i750, dan zou de waarde van veld prijs moeten ingevuld worden, zie onderstaand voorbeeld.
code:
1
2
3
4
                  prijs
klant   MB
CPU     i750      175
totaal            175

Nu is het probleem, hoe kan je dat doen? Het lijkt me iets triviaal maar als spreadsheet-noob weet ik het toch even niet.

Acties:
  • 0 Henk 'm!

  • Punkie
  • Registratie: Oktober 2005
  • Laatst online: 26-04 20:11
Oplossing
Weet niet of dit snel en efficiënt is maar het werkt.

Ten eerste zoeken we de positie in de koppelingstabel voor de overeenkomstige waarde van veld CPU in de invoertabel op.
invoerveldCPU is een referentie naar het veld in de invoertabel waarin de i750 hebben geschreven, eg B3
koppelingstabelCellrange is de range met de mogelijke waarden voor veldCPU, eg SheetKoppeling.A2:A4
code:
1
=match(invoerveldCPU ;koppelingstabelCellrange)

resultaat hiervan is 1 (1e cell in de range)
Met deze positie zoeken we de waarde op van de prijs mbv de functie offset
code:
1
=offset(koppelingstabel;1;match(invoerveldCPU ;koppelingstabelCellrange)-1;1)


Nadeel is dat dit allemaal met de hand in elkaar gedraaid moet worden. Men kan nog een column lookup doen (dmw match) om de juiste kolom "prijs" te zoeken ipv hard coded een spring van 1 te maken. Bovendien zijn de cell ranges, startposities etc niet dynamisch uitbreidbaar.
Iemand een beter idee/bemerkingen?

Acties:
  • 0 Henk 'm!

  • farmertjes
  • Registratie: Maart 2010
  • Laatst online: 02-06 20:29

flickr


Acties:
  • 0 Henk 'm!

  • Punkie
  • Registratie: Oktober 2005
  • Laatst online: 26-04 20:11
idd die Vlookup of hlookup zijn eigenlijk functies die een combinatie van offset en match zijn
dus zoiets als
code:
1
=VLOOKUP(cpu;koppeling.A1:K40;MATCH(prijs;koppeling.A1:H1);0)

haalt de prijs voor een product "cpu".
bedankt :)