Delphi Can

Orjinalini görmek için tıklayınız: Delphi Editor ile hızalama
Şu anda (Arşiv) modunu görüntülemektesiniz. Orjinal Sürümü Görüntüle internal link
selam arkadaşlar

 tc adı soyadı sicil ve tutar kısmını hepsini hizada yapmak istiyorum. Bir türlü beceremedim rica etsem yardımcı olurumsunuz. 

AŞAĞIDAKİ GİBİ YAPMAYA ÇALIŞIYORUM AMA BECEREMEDİM 

1478523612345678912DENEME      DENEME SOYAD      1236548      000000000120.00
1486222232145698741DENEME1     DENEME SOYAD     1147852      000000000052.00

Form üzerindeki memo nesnesinde bu dediğinizi yapmak istiyorsanız, font tipini "Courier New" olarak değiştirin ve karakter sayısına göre kelime aralarına ilave edeceğiniz boşluk karakteri sayısını hesaplayarak sonrasında araya boşluk karakteri ekleyerek yapabilirsiniz.
Dediğiniz gibi yaptım ama gine olmadı. sütunlar sıralı şekilde çıkmıyor.

kod kısmının bir bölümü bu şekilde

type myproctype=procedure(maskno:byte) of object;
d_rec1=record
d_sube_kodu:string[4];
d_KURUM_kodu:string[2];
d_islem_ayi:string[2];
d_odeme_turu:string[1];
d_bos:string[10];

d_musteri_hesap_no:string[8];
d_sss_soyadi: string[13];
d_sss_adi:string[12];
d_sicil_no:string[9];
d_miktar:currency;
d_kimlik_no:string[11];
---------------------------------------------------
d_kurum_kodu:= d_kurum_kodu1;

hesap1:=''+hesap;
hesap2:=query1.FieldByName('BANKA_HES2').AsString;
d_musteri_hesap_no:=hesap2;
d_kimlik_no:=(query1.fieldbyname('KIMLIK_NO').ASSTRING);
d_sss_adi:=query1.fieldbyname('ADI').AsString ;
d_sss_soyadi:=query1.fieldbyname('SOYADI').AsString;
numara :=floattostr(query1.fieldbyname('SICIL_NO').Asfloat);
for jj:=1 to (12-length(numara)) do
sifir_str:=sifir_str+'';
d_sicil_no:=sifir_str+numara;
d_miktar:=query1.FieldByName('TUTAR').AsFloat;
d_odeme_turu:=UPPERCASE(Edit2.text);

d_bos:=' ';
yeni_deger := StringReplace(formatfloat('0###########.00',d_miktar) , ',', '.',
[rfReplaceAll, rfIgnoreCase]);


// disket rapor kısmı sıralaması

satir_str1:= d_musteri_hesap_no+
d_kimlik_no+
d_sss_adi+' '+
d_sss_soyadi+ ' '+
d_sicil_no+ ' '+
yeni_deger ;
Paylaştığınız kod parçacığında yukarıdaki mesajda önerdiğim çözüm yöntemini uyguladığınızı göremedim.

Daha basit şekilde yukarıdaki örneği şu şekilde uygulayabilirsiniz. Her sütünunda hizalamaya çalıştığınız içeriklerin max uzunluğu belli ise, ve belirli sütünlardaki kelime uzunlukları eşit ise (ör: kimlik no) kelimelere ayırmak ve bunları dinamik işlemek yerine daha statik bir yaklaşım kurgulanabilir.

Hizalama ihtiyacınıza göre  boşluk sayısını değiştirebilirsiniz.

Aşağıdaki kodlar doğrudan çalışmayacaktır, probleme yaklaşım yöntemi konusunda size fikir vermesi içindir.



var maxuzunluk:integer = 20; //sss_adi en fazla 20 karakter veri içerebilir.
.....

memo1.Font.Name:= 'Courier New';

......
satir_str1:=d_musteri_hesap_no+ '5 adet boşluk' + // hesap no fix uzunlukta 
d_kimlik_no+ '5 adet boşluk' + // kimlik no fix uzunlukta 
d_sss_adi+ 'maxuzunluk-length(d_sss_adi) kadar boşluk' + '5 adet boşluk' + // sss_adi uzunluğu dinamik 
d_sss_soyadi+ ......
d_sicil_no+ ......
yeni_deger ;

memo1.lines.add(satir_str1);

Font tipini Courier New yaptıktan sonra
Satır satır girişi Format()  fonksiyonu kullanmak da isteyebilirsiniz.

FORMAT( '%-20s %.5d', ['abc', 123] )

gibi deneyin isterseniz.
@mrmarman  beyin çözüm önerisi çok daha pratik. Shy