Avatar billede jekk Nybegynder
09. september 2007 - 11:40 Der er 5 kommentarer og
1 løsning

hvordan konverterer man dato i et str-felt til num-værdi ?

datoen (dd-mm-åååå) gemmes i et karakterfelt i en dbf-fil
det ønskes konverteret til et talfelt - således at talværdien angiver / svarer til dato-rækkefølgen....

illustreret eksempel:
dato 1  10-09-2007  svarer til tallet 4711
dato 2  09-09-2007  svarer til tallet 4710
Avatar billede softtail Nybegynder
09. september 2007 - 12:00 #1
Det er et godt spørgsmål, men jeg vil tro du kun trylle en del med funktionerne

EncodeDate
DecodeDate
Copy
Avatar billede martinlind Nybegynder
09. september 2007 - 13:42 #2
StringToDateTime er der vist også en funk. der hedder, ellers så kig i DateUtils unit'en
Avatar billede arne_v Ekspert
09. september 2007 - 15:54 #3
Hvis du kan leve med spring på mere end 1 så:

function ConvDateStrToInt1(s : string) : integer;
function ConvDateStrToInt2(s : string) : integer;
var
  dt : TDateTime;
begin
  ShortDateFormat := 'dd-mm-yyyy';
  dt := StrToDate(s);
  ConvDateStrToInt2 := trunc(dt);
end;
Avatar billede arne_v Ekspert
09. september 2007 - 15:55 #4
Om igen.

Hvis du kan leve med spring på mere end 1 så:

function ConvDateStrToInt1(s : string) : integer;
var
  d, m, y : integer;
begin
  d := StrToInt(Copy(s, 1, 2));
  m := StrToInt(Copy(s, 4, 2));
  y := StrToInt(Copy(s, 7, 4));
  ConvDateStrToInt1 := Y * 31 * 12 + m * 31 + d;
end;

ellers så brug:

function ConvDateStrToInt2(s : string) : integer;
var
  dt : TDateTime;
begin
  ShortDateFormat := 'dd-mm-yyyy';
  dt := StrToDate(s);
  ConvDateStrToInt2 := trunc(dt);
end;
Avatar billede jekk Nybegynder
09. september 2007 - 16:13 #5
tak for svarene ...
arne_v>>>
det ligner noget kode, der løser mit behov, som jeg straks vil afprøve !
send mig et svar ....
Avatar billede arne_v Ekspert
09. september 2007 - 18:20 #6
svar
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