Oprettet tor. d. 11. marts 2010 kl. 02:12:51

jokerper
jokerper (8.591 point. Point ude: 100)

VBA hjælp - error handling

Hejsa eksperter

Jeg har et "lille" problem, jeg ved ikke præcist hvordan jeg skal takle dette.

Private Sub Workbook_Open()
On Error GoTo ErrHandler:
Call koden

ErrorHandle:
exit sub
End sub

Nu er det sådan at jeg vil slette koden - "koden" efter Workbook_Open første gang den åbnes.

Derfor har jeg brug for at den ikke melder fejl, når workbooken åbnes næste gang og ikke kan finde call koden.

Hvordan kan jeg gøre dette?

Skrevet tor. d. 11. marts 2010 kl. 07:50:55| #1

jokerper
jokerper (8.591 point)
Jeg tror nu jeg klarede det ved at bruge run kommandoen i stedet for.

Skrevet tor. d. 11. marts 2010 kl. 11:14:28| #2

kabbak
kabbak (151.384 point)
www.kabbak.dk
Slet koden 'Workbook_Open()' også

Skrevet tor. d. 11. marts 2010 kl. 11:26:24| #3

kabbak
kabbak (151.384 point)
www.kabbak.dk
Du har denne kode i ThisWorkbook modulet

Private Sub Workbook_Open()
On Error GoTo ErrHandler:
Call koden

ErrorHandle:
exit sub
End sub


Her er en måde at slette kode på, sæt den i Module1

Public Sub koden()
' din nuværende Kode
Call DeleteCode
End Sub
Sub DeleteCode()

''Needs Reference Set To _

  '  "Microsoft Visual Basic For Applications Extensibility"

'Tools>References.
       
    With ThisWorkbook.VBProject.VBComponents("ThisWorkbook").CodeModule
            .DeleteLines 1, .CountOfLines
    End With

    With ThisWorkbook.VBProject.VBComponents("Module1").CodeModule
            .DeleteLines 1, .CountOfLines
    End With
                               

End Sub


det vil sige koden kører 1 gang og sletter så sig selv

Skrevet tor. d. 11. marts 2010 kl. 11:39:54| #4

jokerper
jokerper (8.591 point)
Hej kabbak

Det vil også slette min beforeclose kode, ik´?

Det skal den nemlig ikke, kan du evt. lige sætte lidt kommentarer i koden så jeg kan forstå hvad der sker.

Det jeg vil forsøge er at lave noget sikkerhed således at det kun kan åbnes på een computer ved at huske hvor det er installeret, og slette muligheden for at ændre min sub koden herefter ved at slette sub koden.

Håber det er forståeligt?

Jeg har til en vis grænse løst det men for at undgå fejl meddelelser, kunne det være godt at se lidt andre muligheder.

Skrevet tor. d. 11. marts 2010 kl. 11:48:38| #5

kabbak
kabbak (151.384 point)
www.kabbak.dk
OK, jeg prøver at forklare

Sub DeleteCode()

''Needs Reference Set To _

  '  "Microsoft Visual Basic For Applications Extensibility"

'Tools>References.
     
    With ThisWorkbook.VBProject.VBComponents("ThisWorkbook").CodeModule
            .DeleteLines 3' sletter KUN linje 3 i ThisWorkbookmodulet
    End With

    With ThisWorkbook.VBProject.VBComponents("Module1").CodeModule
            .DeleteLines 1, .CountOfLines' sletter alle linjer i Module1
    End With
                             

End Sub

Skrevet fre. d. 12. marts 2010 kl. 17:08:49| #6

jokerper
jokerper (8.591 point)
Okay tak, kabbak -> Den var sku´godt nok lidt svær at få til at spille rigtigt.


Men kan få excel til automatisk at vælge/indlæse referencer?

''Needs Reference Set To _

  '  "Microsoft Visual Basic For Applications Extensibility"

'Tools>References.

Lægger du et svar, så godkender jeg det.

Skrevet fre. d. 12. marts 2010 kl. 19:15:30| #7

jokerper
jokerper (8.591 point)
Et eks. jeg syntes ikke det er alle pc´er som fx kan genkende denne kommando

Textbox1.value = Date

Mens det virker på andre

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Svar til: X i en celle giver et andet resultat i anden...

Oprettet den 11. februar 2012 kl. 14.15
ashurra giver 100 point for svar | Giv et svar »

Hjælp til formel rente/antal dage

Oprettet den 11. februar 2012 kl. 12.14
petert giver 30 point for svar | Giv et svar »

Problemløser, "HVIS" formel, eller andet til optimering?

Oprettet den 11. februar 2012 kl. 02.36
Olav123 giver 150 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger