03 Aralık 2011, 16:55 | #1 | |
Çevrimdışı
Kullanıcıların profil bilgileri misafirlere kapatılmıştır.
IF Ticaret Sayısı: (0) | Delphi String Fonksiyonlar. Delphi String Fonksiyonlar AnsiCompareStr(Aranacak_Metin,İçinde_Aranacak); Birinci parametre ile girilecek olan metni, ikinci parametrede aramak için kullanılan bir fonksiyondur. Şayet ilk parametre ikinci parametrenin içerisinde bulunuyorsa pozitif, bulunmuyorsa negatif, iki metin aynı ise sıfır değeri dönecektir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Fonksiyonun kullanımında küçük büyük harf kullanımına dikkat etmelisiniz. Aksi takdirde farklı sonuçlar oluşturabilirsiniz. AnsiCompareText(Aranacak_Metin,İçinde_Aranacak); AnsiCompareStr fonksiyonu ile aynı işi yapar. Yalnız bu fonksiyonun kullanımı küçük-büyük harf duyarlılığına hassas değildir. Yani ali ile ALI nin aynı oldukları kabul edilecektir. (Fonksiyondan geriye sıfır değeri dönecektir) Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiDequotedStr(Metin , Karakter); İkinci Parametre ile belirtilen karakteri, birinci parametre ile belirtilen metnin ilk harfinde arar. Şayet bulursa ilk ve son karakteri atarak kalan değeri döndürür. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Fonksiyonda kullanılan parametre değerlerinin küçük büyük harf duyarlılığının bulunduğunu hatırlatıp, diğer fonksiyonları incelemeye devam edeceğim. AnsiLeftStr(Metin , Adet); Bu fonksiyonu kullanabilmemiz için uses satırına StrUtils kütüphanesini eklememiz gerekir. Bu fonksiyonda birinci parametreyle belirtilen metnin sol tarafından, ikinci parametreyle belirtilen adet kadar karakter sökülüp alınabilir. Fonksiyondan geriye dönecek olan değer AnsiString tipli bir veri içereceği için her hangi bir kontrolde direk yazdırılabilir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiLowerCase(Metin); Parametre değeri ile girilen metnin küçük harfe çevirmek için kullanılan bir fonksiyondur. Şayet parametre içerisinde küçük harflerden oluşan karakterlere rastlarsa onlara dokunmaz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiMidStr(Metin , Başlangıç , KaçAdet); Birinci parametre ile belirtilen metinden, ikinci parametredeki karakterden sonra, üçüncü parametre ile belirtilen sayı kadar karakteri söküp alır. Fonksiyondan geriye dönen değer AnsiString tipte bir veri olacağı için kolayca yazdırabilirsiniz. Uses’ e StrUtils eklemeyi unutmayınız. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiPos(Aranacak_Metin , İçinde_Aranan_Metin); İkinci parametre içerisinde birinci parametreyle girilen değeri arar. Şayet bulursa ilk karakterin kaçıncı karakterde bulunduğunu, bulmazsa da sıfır değerini döndürür. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Şimdi bu fonksiyona güzel bir örnek verelim. Örneğimizde Edit kutusuna girilecek olan dosya adında (uzantısıyla beraber) ”.” karakteri aratılmakta, ardından dosya adı Edit2 ye, uzantısı da Edit3 e yazdırılmaktadır. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiReplaceStr(Metin , Değişecek_Metin , Yeni_Metin); Birinci parametre ile girilen metin içerisindeki, ikinci parametre ile belirtilen bölümün yerine, üçüncü parametre ile belirtilen metni aktarabilen bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiReplaceText(Metin , Değişecek_Metin , Yeni_Metin); AnsiReplaceStr ile aynı işi yapar. Aralarında tek fark bu fonksiyonun harf duyarlılığının olmamalısır. Yeni aranan değerin var veya Var olması fonksiyon için fark etmeyecek, metni değiştirecektir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiReverseString(Metin); Parametre ile girilen metin değerini ters çevirere, yeni bir metin oluşturan fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Fonksiyondan geriye dönen değer AnsiString tipte bir içeriğe sahip olduğu için başlıkta dönüştürme yaptırmadan yazdırabilmektir. AnsiRightStr(Metin , Sağdan_Kaç_Karakter); Birinci parametre ile girilen metnin sağ tarafından (sonundan), ikinci parametre ile belirtilen sayı kadar karakteri söküp alabilen bir fonksiyondur. Uses’ e StrUtils eklemeyi unutmayalım. Kod: Kodu kopyalamak için üzerine çift tıklayın!
AnsiUpperCase(Metin); Parametre ile girilen metni büyük harfle yazdırabilmek için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
CompareStr(Metin1 , Metin2); Birinci ve ikinci parametre ile girilen metinlerin eşit olup olmadıklarını kontrol edebilen bir fonksiyondur. İkinci metnin içerisinde birinci metni arar, şayet bulursa negatif, bulmazsa pozitif, ikisi aynı ise sıfır değerini döndürür. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Fonksiyon büyük küçük harfe hassas bir şekilde çalışmaktadır. Yani ilk parametrenin (metnin) değerini prestige (hepsi küçük) olarak değiştirirseniz, içinde yok kısmı işleyecektir. CompareText(Metin1 , Metin2); CompareStr fonksiyonu ile aynı işi yapar. Aralarında ki tek fark bu fonksiyonun harf duyarlılığının olmamasıdır. Fonksiyondan geriye döndürdüğü değer pozitif sayı, negatif sayı veya sıfırdır. Bu değeri basit bir dallanmaya tabii tutarak, ikinci metnin içerisinde birinci metnin (harf duyarlılığı olmadan) var olup olmadığını kolayca öğrenebilirsiniz. CompareStr fonksiyonu ile çalışma mantığı benzeştiği için burada örneklendirme yapmamayı uygun buldum. (Siz isterseniz aynı örneği çözebilirsiniz) Contact(Metin1, Metin2, ……….); Parametre ile belirtilen değişken değerlerini yan yana yazdırmak için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Şayet arada boşluk bırakılması istenirse, o zaman kodu aşağıdaki şekilde değiştirmelisiniz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Copy(Metin1 , İndex, Adet); Birinci parametre ile girilen metnin içeriğinden, ikinci parametrede belirtilen karakterden sonra, üçüncü parametreyle belirtilen adet kadar karakteri söküp alabilen bir fonksiyondur. Fonksiyondan geriye dönen değer yine bir AnsiString veri olacağı için sonuç herhangi bir tip dönüştürme işlemine gerek kalmadan direk olarak yazdırılabilir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Delete(Metin1 , İndex, Adet); Birinci parametre ile girilen metnin değerinden, ikinci parametre ile girilen karakterden sonra, üçüncü parametreyle belirtilen sayı kadar karakteri söküp atan bir prosedürdür. Dikkat edeceğiniz husus, yapılan değişikliğin metin isimli parametrenin değerine yansıyacağıdır. Kod: Kodu kopyalamak için üzerine çift tıklayın!
DupeString(Metin , Adet); Birinci parametre ile girilen metni, ikinci parametre ile girilen adet kadar yan yana yazmak için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Insert(Eklenecek_Metin , Metin_Başlangıç_Karakteri); Birinci parametre ile girilen metni, ikinci parametre ile girilen metre, üçüncü parametre de belirtilen karakterden sonra eklemek için kullanılan bir prosedürdür. Burada dikkat edilmesi gereken husus, yapılan değişikliğin ikinci parametre değerine yansıyacağıdır. Kod: Kodu kopyalamak için üzerine çift tıklayın!
LeftBStr(Metin , Adet); Birinci parametre ile belirtilen metinden, ikinci parametre ile belirtilen adet kadar karakteri söküp alabilen bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Daha öncede aynı işlemi yapan fonksiyonu göstermiştim. Başında Ansi olan fonksiyon ve prosedürlerin kullanabileceği karakter daha fazladır. Ama tercih tamamen size kalmıştır. İstediğiniz fonksiyonu veya prosedürü kullanabilirsiniz. Length(Metin); Parametre ile belirtilen metnin kaç karakterden oluştuğunu hesaplayabilmek için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Fonksiyondan geriye dönen değer tam sayı tipli olacağı için, form başlığına tip dönüştürme fonksiyonu sayesinde yazdırılabilmektedir. LowerCase(Metin); AnsiLowerCase (daha önce izah edildi) fonksiyonunun yaptığı işi yapar. (Ansi kütüphanesinin daha zengin olduğunu hatırlatalım) Parametre olarak girilen metni küçük harfe dönüştürmek için kullanılır. MidStr(Metin, Başlangıç, Adet); Birinci parametre ile belirtilen metinden, ikinci parametre ile girilen başlangıç başlangıç karakterinden başlayarak, üçüncü parametre ile girilen adet kadar karakteri parçalayıp almak için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Pos(Metin1, Metin2); Birinci parametre ile girilen değer ile ikinci parametre ile girilen değeri karşılaştırmak için kullanılan bir fonksiyondur. Şayet iki parametre farklı değerler içeriyorsa (içinde bulunmuyor ise) 0 olacaktır. Kod: Kodu kopyalamak için üzerine çift tıklayın!
RightStr(Metin, Sağdan_Kaç_Karakter); Birinci parametre ile belirtilen metnin sonundan, ikinci parametre ile belirtilen adet kadar karakteri söküp almak için kullanılan fonksiyondur. (AnsiRightStr fonksiyonunun yaptığı işi yapar) Kod: Kodu kopyalamak için üzerine çift tıklayın!
SetLength(Metin, Soldan_Kaç_Karakter); Birinci parametre ile belirtilen metinden, ikinci parametre ile belirtilen adet kadar karakteri söküp alabilen bir prosedürdür. Kod: Kodu kopyalamak için üzerine çift tıklayın!
SetString(Metin, Katar, Soldan_Kaç_Karakter); Birinci parametre ile belirtilen metne, ikinci parametre ile belirtilen katarın, üçüncü parametre ile belirtilen adet kadar karakterini (soldan) aktarabilen bir prosedürdür. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Str(Sayı , Metin); Birinci parametre ile girilen sayıyı (ondalıklı veya tam sayı), ikinci parametre ile girilen metne aktarmak için kullanılan bir prosedürdür. İlk parametre parasal tipte bir değişkende olabilir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
StringOfChar(Karakter , Adet); Birinci parametre ile belirtilen karakteri, ikinci parametre ile belirtilen adet kadar yan yana yazdırmak için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Görsel diller çıkmadan önce çok kullanılan (hakikaten işe yarardı) bir fonksiyondu. (Pascal, C vs.) Bilhassa başlık ve paragraf altlarını çizdirmek için kullanılırdı. Biliyorum hepiniz Edit kutusuna girilen karakteri yan yana yazdırmayı deneyeceksiniz, ama olmayacak. Unutmayınız ki Char tipli değişkenlerde AnsiString tipli veriler aynı değildir. Bu tip durumlarda izleyeceğiniz yol aşağıda ki gibi olmalıdır. Kod: Kodu kopyalamak için üzerine çift tıklayın!
StringReplace(Metin, Değişecek_Bölüm, Yeni_Bölüm, Seçenek); Birinci parametre ile verilen metnin içerisinde, ikinci parametre ile verilen kısmı, üçüncü parametre ile verilen içerikle değiştirmek için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Aynı kodu aşağıdaki şekilde yazarsanız bu durumda küçük büyük harf duyarlılığı gösterecek dolayısı ile sonuçta farklı olacaktır. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Burada kullanılan TReplaceFlags nesnesi küme tipte Delphi tarafından tanımlanmış bir nesnedir. Dilerseniz gösterimini aşağıdaki şekilde de kullanabilirsiniz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Her iki durumda da sonuç aynı olacaktır. [] işareti içerisinde kullanmayı sakın unutmayın. StuffString(Metin, Başlangıç, Uzunluk, Yeni_Metin); StringReplace fonksiyonuna benzer iş görmektedir. Aralarında ki fark, değiştirilecek olan kısmın burada karakter sayısı ile belirlenmesidir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Trim(Metin); Parametre ile girilen metnin sol ve sağındaki tüm boşlukları atmak için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Bilhassa yanlışlık ile space tuşuna basılması durumunda oluşabilecek olan hataları engellemek amacıyla kullanılan bir fonksiyondur. Bu fonksiyondan dolayı kelimeler arasında bulunan boşluklar hiçbir değişikliğe uğramazlar. TrimLeft(Metin); Parametre ile girilen metnin sol tarafında bulunan boşlukları atmak için kullanılan bir fonksiyondur. Sağ kısımda bulunan boşluklara dokunmaz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
TrimRight(Metin); Parametre ile girilen metnin sağ tarafında bulunan boşlukları atmak için kullanılan bir fonksiyondur. Sol kısımda bulunan boşluklara dokunmaz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
UpperCase(Metin); Parametre ile girilen metindeki karakterlerin tamamını büyük harfe çevirmek için kullanılan fonksiyondur. Şayet metnin içerisinde büyük harfe rastlarsa onlara dokunmayacaktır. Daha önce örneklendirildiği için tekrar değinilmeyecektir. WrapText(Metin, İşlem, Alta_İndirilecek_Karakterler, Max_Karakter); Birinci parametrede belirleyeceğiniz metni, üçüncü parametrede belirleyeceğiniz karakterlerden herhangi bir tanesine rastlaması durumunda alt satıra indirmek için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Komutta da görüldüğü üzere space rastladığında alt satıra kalan karakterleri devam etmektedir. Chr(Sayi); Parametre ile girilen ASCII (0-255 arası) değerinin karakter karşılığını bulmak için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Ord(Karakter); Parametre ile girilen karakterin ASCII değerini hesaplayan bir fonksiyondur. Fonksiyondan tam sayı tipli bir değer döneceği için yazdırmak için IntToStr tip dönüştürme fonksiyonunu kullanmalısınız. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Val(Metin , Değişken , Hata); Birinci parametreyle girilen içeriğin soldan matematiksel anlamı olan kısmını ikinci parametreye aktarır. Prosedür sayesinde ikinci parametrenin değeri değişecektir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
StrToInt(Metin); String içerikli değerleri tam sayıya çevirmek için kullanılan bir fonksiyondur. Sayısal içeriğe çevrilemeyen bir karaktere rastlarsa hata üretecektir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
StrToIntDef(Metin); StrToInt fonksiyonu ile aynı işi yapar. Aralarındaki tek fark şayet sayıya dönüştürülemeyecek bir değer gönderilirse, bu durumda fonksiyon hata üretmemekte, ikinci parametre ile belirtilen değeri işleme sokmaktadır. Farkı anlamanız için aşağıdaki iki örneği dikkatlice inceleyiniz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Üstteki kodlamada metin değişkeninin içeriğinde A karakteri (sayıya çevrilemez) bulunduğu için, değer isimli değişkenin içeriği ikinci parametre ile girilen 0 değerine eşit olacaktır. Bu aktarmayı StrToInt fonksiyonu ile yaparsanız programınız size hata mesajı vericektir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
StrToFloat(Metin); Parametre ile girilen metni ondalıklı sayıya çevirmek için kullanılan bir fonksiyondur. Ondalıklı sayıya çevrilemeyecek bir karaktere rastlarsa programınız hata mesajı verecektir. Kod: Kodu kopyalamak için üzerine çift tıklayın!
StrToFloatDef(Metin); Ondalıklı sayıya çevrilemeyen bir karaktere rastlanılması durumunda StrToFloat fonksiyonu hata mesajı veriyordu. Bu fonksiyonla hata mesajını engelleyip varsayılan değerin kullanılmasını sağlayabilirsiniz. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Metin değişkeni içerisinde ondalıklı sayıya çevrilemeyecek karaktere rastladığı için değer isimli değişkenin içeriğini varsayılan (yani 0) kabul ederek işleme devam edecektir. IntToStr(Sayı); Parametre olarak girilen tam sayıyı stringe çavirmek için kullanılan fonksiyondur. Bilhassa kullanıcının görmesini istediğiniz içerilikleri stringe çevirmek zorunda kalacaksınız. FloatToStr(Ondalıklı_Sayı); Parametre olarak girilen ondalıklı sayıyı string içeriğe çevirmek için kullanılan fonksiyondur. Diğer fonksiyonlarda yeterince uygulama yapıldığı için tekrar örnek verilmeyecektir. FloatToStrF(Ondalıklı_Sayı, Format, Uzunluk, Ondalıklı_Uzunluk); Birinci parametre ile girilen ondalıklı sayıyı ikinci parametrede belirtilen formatlı hale dönüştürmek için kullanılan bir fonksiyondur. Kod: Kodu kopyalamak için üzerine çift tıklayın!
Fornksiyonda kullanılan birinci parametre, formatlanacak olan sayıyı, üçüncü parametre toplam karakteri sayısı, dördüncü parametrede ondalıklı kısımda gözükecek olan karakter sayısını belirlemek için kullanılmaktadır. İkinci parametre ise uygulanacak olan formatı belirleyecek olan bölümdür. Alabileceği seçenekler aşağıda verilmiştir. ffCurrency Parasal format için kullanılır. ffNumber Binlik ayıraç uygulanmış halde gösterilir. ffFixed Ondalıklı formatta gösterilir. ffExponent Sayı üstel olarak gösterilir. ffGeneral Üstel veya normal gösterim. Parasal formatın nasıl olacağı (TL-$) Windows unuzun bölgesel ayarlar kısmından otomatik olarak alınmaktadır. Eğer bölgesel ayarlar kısmından Türkiye seçilmiş ise, paranızın sonuna Delphi tarafından TL otomatik olarak konulacaktır. Şayet USA seçilmiş ise o zamanda $ karakteri paranızın sonunda otomatik olarak eklenecektir. FormatFloat(Format_Tipi, Sayı); İkinci parametre ile girilen ondalıklı sayıya, birinci parametre ile belirlenen formatı uygulayan fonksiyondur. Birinci parametre için belirleyebileceğiniz format tipleri aiağıda verilmiştir. #,##0.00 1,234.00 #.## 1234 0.00 1234.00 Kod: Kodu kopyalamak için üzerine çift tıklayın!
Kaynak:Alıntıdır. | |
|
Etiketler |
delphi, fonksiyonlar, string |
Konuyu Toplam 1 Üye okuyor. (0 Kayıtlı üye ve 1 Misafir) | |
| |
Benzer Konular | ||||
Konu | Konuyu Başlatan | Forum | Cevaplar | Son Mesaj |
Delphi String Fonksiyonlar | Slipknot | Delphi | 0 | 07 Temmuz 2010 20:59 |
C# Fonksiyonlar | Sunay | C# | 0 | 24 Nisan 2010 01:54 |