Oprettet søn. d. 08. november 2009 kl. 11:57:58

petert
petert (6.375 point. Point ude: 540)

Omskrivning af datoformat.

Hvis jeg eks. i en celle har et datoformat således October 19, 2009, 11:54:08 AM
hvordan formaterer jeg så cellen til at vise datoen som
19 okt.09 11:54:08
Alternativ
hvis jeg i A1 har datoen October 19, 2009, 11:54:08 AM
hvordan kan jeg splitte denne op, så der i B2 står 19 Okt.2009
og kun klokkeslettet skrives i C2 som 11:54:08 (uden AM)
Mvh
Petert

Skrevet søn. d. 08. november 2009 kl. 14:45:03| #1

rosco
rosco (20.177 point)
=A1 Formatteret som 19 Okt.2009 eller som tt:mm:ss

Skrevet søn. d. 08. november 2009 kl. 15:21:26| #2

petert
petert (6.375 point)
Jeg har prøvet at indsætte forslaget. men det ændres ikke. Hvad kan jeg prøve.
Mvh
Petert

Skrevet søn. d. 08. november 2009 kl. 16:44:40| #3

tjacob
tjacob (36.388 point)
Problemet er at formatet ikke genkendes som et datoformat, så uanset hvordan du formaterer cellen vil den ikke gøre det korrekt. Problemet er dels kommaerne, og dels de engelske månedsbetegnelser.

Det nemmeste (for mig) er at lave en brugerdefineret funktion til at "oversætte" formatet.
Denne funktion outputter an komplet dato med klokkeslet i Excels eget datoformat, dvs at du med formatteringen af målcellerne kan få vist hvad du vil.

Indsæt denne funktion i et modul i Visual Basic:
(sig til hvis du skal have hjælp til dette)

Public Function FindDato(ByVal pStr As String) As Double
   
    Dim sDato As String, pDato As Date, lOut As Double
    sDato = Left(pStr, Len(pStr) - 13)
    sDato = LCase(sDato)
    sDato = Replace(sDato, "january", "januar", 1, , vbTextCompare)
    sDato = Replace(sDato, "february", "februar", 1, , vbTextCompare)
    sDato = Replace(sDato, "march", "marts", 1, , vbTextCompare)
    sDato = Replace(sDato, "may", "maj", 1, , vbTextCompare)
    sDato = Replace(sDato, "june", "juni", 1, , vbTextCompare)
    sDato = Replace(sDato, "july", "juli", 1, , vbTextCompare)
    sDato = Replace(sDato, "october", "oktober", 1, , vbTextCompare)
    pDato = sDato
    lOut = DateSerial(Year(pDato), Month(pDato), Day(pDato))
    pDato = Right(pStr, 11)
    lOut = lOut + TimeSerial(Hour(pDato), Minute(pDato), Second(pDato))
    FindDato = lOut

   
End Function

Nu kan du bruge funktionen ved i en celle at skrive: =FindDato(A1) (med datostrengen i A1)

Du skal formattere cellen med brugerdefineret format: dd mmm åååå tt:mm:ss
eller: dd mmm åååå (kun datoen)
eller: tt:mm:ss (kun klokkeslettet)

Skrevet søn. d. 08. november 2009 kl. 16:46:37| #4

tjacob
tjacob (36.388 point)
tags blev forkert placeret, sådan:

Public Function FindDato(ByVal pStr As String) As Double
   
    Dim sDato As String, pDato As Date, lOut As Double
    sDato = Left(pStr, Len(pStr) - 13)
    sDato = LCase(sDato)
    sDato = Replace(sDato, "january", "januar", 1, , vbTextCompare)
    sDato = Replace(sDato, "february", "februar", 1, , vbTextCompare)
    sDato = Replace(sDato, "march", "marts", 1, , vbTextCompare)
    sDato = Replace(sDato, "may", "maj", 1, , vbTextCompare)
    sDato = Replace(sDato, "june", "juni", 1, , vbTextCompare)
    sDato = Replace(sDato, "july", "juli", 1, , vbTextCompare)
    sDato = Replace(sDato, "october", "oktober", 1, , vbTextCompare)
    pDato = sDato
    lOut = DateSerial(Year(pDato), Month(pDato), Day(pDato))
    pDato = Right(pStr, 11)
    lOut = lOut + TimeSerial(Hour(pDato), Minute(pDato), Second(pDato))
    FindDato = lOut
   
End Function

Skrevet søn. d. 08. november 2009 kl. 18:35:24| #5

petert
petert (6.375 point)
Det ser super ud. Hvordan indsætter jeg denne funktion.
Ændre det noget at det er i hele kolonne D fra række 2 og ned jeg vil ændre disse datoer?
Skal denne så ændres"=FindDato(A1) (med datostrengen i A1)"?
MVH
Petert

Skrevet søn. d. 08. november 2009 kl. 18:50:23| #6

tjacob
tjacob (36.388 point)
Du indsætter funktionen således:

-Tryk Alt+F11 for at åbne Visual Basic
-i det øverste venstre vindue: Højreklik i VBAProject og vælg Insert>Module
-I den store rude til højre indsæt funktionen

Nu kan du i selve regnearket i en hvilken som helst celle indsætte funktionen ved at skrive: =FindDato(X)

Hvor X er den celle hvor din datostreng står, altså f.eks. October 19, 2009, 11:54:08 AM

Hvis du har dato strengene stående i D-kolonnen, så kan du i en anden kolonne skrive
=FindDato(D1) i række 1.

Denne formel kan du så trække med musen ned ad kolonnen.

Skrevet man. d. 14. december 2009 kl. 12:18:47| #7

petert
petert (6.375 point)
Tak for svaret læg et svar så vi kan lukke dette
Mvh
Petert

Skrevet fre. d. 09. juli 2010 kl. 14:36:02| #8

petert
petert (6.375 point)
Hej Læg et svar så jeg kan luke dette.
Tak for hjælpen
MVH
Petert

Skrevet lør. d. 31. juli 2010 kl. 07:00:38| #9

petert
petert (6.375 point)
Jeg lukker dette. Tak for hjælpen.
Mvh
Petert

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