Video: Skapa en VBA-funktion med Excel 2010 2024
VBAs IsDate-funktion talar förmodligen om en textsträng kan tolkas som ett datum. Till exempel utvärderar alla följande uttryck till True:
IsDate ("5/25/2015") IsDate ("16 januari") IsDate ("12-1") IsDate ("12/1/15") IsDate ("2/30") IsDate ("30/2")
I de två senaste exemplen märker du att IsDate inte är picky om dagens och månadens ordning. Båda dessa strängar kan tolkas som ett datum, så IsDate returnerar True (oavsett inställningar för systemdatumsformat).
Här finns en del information från en Microsoft Support-artikel:
VBA-datumfunktionerna IsDate, Format, CDate och CVDate använder en funktion som finns i OLE Automation (OleAut32. Dll). Denna funktion söker alla möjliga datumformat genom att tokenera varje av de separerade värdena i strängen som representerar datumet och returnerar ett booleskt värde som anger huruvida ingången kan representeras som ett datum.
Detta är viktigt att komma ihåg när du använder funktionen för att tolka ett datum som innehåller ett 2-siffrigt år. Olika platser använder olika datumformat (det vill säga mm / dd / yy, yy / mm / dd, " DD MMM YY " , " ÅÅ MMM DD " osv.) Och därför försöker funktionen siffrorna i alla positioner tills funktionen har hittat ett giltigt datum eller uttömt alla möjligheter.
Bara för att IsDate känner igen en sträng som ett datum betyder det inte att strängen kan konverteras tillförlitligt till ett datum. I vissa fall är resultatet tvetydigt. Till exempel, vad sägs om detta uttryck?
IsDate ("29 feb-01")
29 februari 2001 är inte ett giltigt datum. Men detta uttryck returnerar True eftersom 1 februari 1929 (och 2 januari 1929) är giltiga datum. Och det är samma datum 2029.
En sökning efter IsDate-dokumentationen kom upp tom. Baserat på test accepterar IsDate något av följande som separatortecken: ett snedstreck (/), en bindestreck (-), ett komma (,), en punkt (.) Och ett mellanslag.
Därför returneras följande uttryck alla True:
IsDate ("5. 1") IsDate ("30 6") IsDate ("30, 6") IsDate ("1/2")
Men då är det här avvikelsen: Följande uttryck returnerar True:
IsDate ("5, 1. 5") IsDate ("5. 1. 05")
Detta uttryck uttrycker emellertid inte False:
IsDate ("5. 1. 2005")
Antag att du skapade en UserForm med en InputBox där användaren anger ett datum. Det bör vara klart att användandet av IsDate för att validera posten inte är mycket tillförlitlig.
Saker blir ännu mer förvirrande när du inser att IsDate också täcker tidsvärden. (Det finns ingen motsvarande IsTime-funktion.) Så följande returnerar alla True:
IsDate ("4: 45") IsDate ("4. 45") IsDate ("4 45") IsDate ") IsDate (" 23: 59 ")
Dessa uttryck returnerar False:
IsDate (" 4: 60 ") IsDate (" 24. 45 ")
Det är viktigt att påpeka att IsDate inte uppvisa alla dessa quirks när du passerar ett Range argument. Till exempel:
IsDate (Range ("A1"))
Det verkar som om IsDate är helt tillförlitlig vid identifiering av celler som innehåller datum eller tid. Det identifierar exempelvis inte en cell som innehåller 5. 1 som ett datum. Om din kod behöver bestämma huruvida en sträng kan tolkas som ett datum, är den bästa lösningen att sätta den här strängen i en cell och skriv sedan kod för att kontrollera innehållet i cellen.