Avatar billede moine Nybegynder
11. november 2009 - 09:24 Der er 6 kommentarer

Tæl ændringer i boolean

Hej

Jeg skriver noget VBA kode til Excel der skal tælle hvor mange gange en boolean skifter fra true til false. Boolean variablen viser status for en ventil i noget udstyr og jeg vil gerne tælle hvor mange gange ventilen lukker (dvs skifter fra true til false)ved at lægge 1 til en integer . Har prøvet med lidt forskelligt men uden held. Nå ja... det må selvsagt være det samme om man tæller hvor mange gange den skifter fra false til true eller det halve af samtlige skift, men det vil være mest praktisk for mig hvis det er skiftene fra åben til lukket der tælles :-)

Nogen der kan lave en stump simpel kode der gør det?
Avatar billede moine Nybegynder
11. november 2009 - 09:26 #1
...nå ja. Status for ventilen skal tjekkes en gang i sekundet (har et loop der sørger for dette), men ventilen skifter status sjældnere, så jeg har tænkt mig at kalde proceduren fra dette loop.
Avatar billede mrgumble Nybegynder
11. november 2009 - 10:54 #2
Ja, det er såmænd meget let:

[code]
If ventstatus <> oldstatus Then
  counter = counter + 1
  oldstatus = ventstatus
End If
[/code]

Men som du måske kan fornemme, så kan du nok ikke direkte indsætte koden til praksis.
Hvordan tjekker du, om ventilen er åben eller ej?
Avatar billede moine Nybegynder
11. november 2009 - 11:56 #3
Jeg henter værdien via et PI add-in i excel. Excel-arket beregnes en gang i sekundet automatisk og så henter jeg værdien fra de relevante celler. Går ud fra at ventstatus skal være forskellig fra oldstatus i koden? serveren har sat spøjse koder ind i stedet;-)

Prøver den ... tak :-)
Avatar billede mrgumble Nybegynder
11. november 2009 - 12:05 #4
Ja, det skal være forskellig-fra. Du skal huske at både oldstatus og counter skal være defineret udenfor løkken.
Avatar billede moine Nybegynder
11. november 2009 - 12:30 #5
jeps... :-) er netop ved at teste den (ventilen skifter kun et par gange i timen, så det tager lidt tid)
Avatar billede moine Nybegynder
16. november 2009 - 16:12 #6
Fandt ud af at oldstatus = ventstatus måtte uden for if'en. Men nu virker det :-)

Skal vi dele pointene?
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester