RSS订阅 | 匿名投稿
您的位置:网站首页 > 字符串 > 正文

Delphi中常用字符串处理函数

作者:admin 来源: 日期:2014/7/25 13:26:49 人气: 标签:


1.copy(str,pos,num) 从str字符串的pos处开始,截取num个字符的串返回.
假设str为'abcdef',copy(str,3,2)='cd',copy(str,4,10)='def' 
2.concat(str1,str2{,strn}) 把各自变量连接起来,返回连接后的字符串(长度不能超过255) 
3.length(str)       返回str的字符个数,即其长度. 
4.pos(obj,target)   在target字符串中找出第一个出现obj的第一个字符位置,如果找不到,返回0. 
5.AnsiStrLastChar('你好')结果是“好”。如果有半个汉字出现,返回这半个汉字。二者字符串长度分别为2和1。 
6.CompareStr  - 区分大小写 
7.CompareText - 不区分大小写 
8.StringReplace(const S, OldPattern, NewPattern: string;Flags: TReplaceFlags): string;
字符串替换函数,需要引用SysUtils单元
rfReplaceAll:全部替换 
rfIgnoreCase:忽略大小写
使用方法Lg:
  str:='01231142211 :655767';//需要把:替换成----
s:=StringReplace(str,':','----',[rfReplaceAll]);
For Example:

var
aStr: String;
begin
aStr := 'This is a book, not a pen!';
ShowMessage(StringReplace (aStr, 'a', 'two', []));   //This is two book, not a pen!只替换了第一个符合的字
ShowMessage(StringReplace (aStr, 'a', 'two', [rfReplaceAll]));
 //This is two book, not two pen!替换了所有符合的字
aStr := 'This is a book, not A pen!';
ShowMessage(StringReplace (aStr, 'a', 'two', [rfReplaceAll]));   //This is two book, not A pen!只替换了符合的字(小写a)
ShowMessage(StringReplace (aStr, 'a', 'two', [rfReplaceAll, rfIgnoreCase]));   //This is two book, not two pen!不管大小写替换了所有符合的字
end;

9.delete 是删除一个 字符串中的 某部分字符
用法是 delete(str,//被删除的字符串 
              index,//从第几个字符开始删除
              count //删除几个
              );
Delete(S, 2, 2); 就是从S中的第二个开始删除,删除2个字符即2、3.所以结果是145. 
////////////////////////////////////////////////////////
LEFTSTR, MIDSTR, RIGHTSTR的介绍
这几个函数都包含在StrUtils中,所以需要uses StrUtils; 
假设字符串是 Dstr := ’Delphi is the BEST’, 那么 
LeftStr(Dstr, 5) := ’Delph’ 
MidStr(Dstr, 6, 7) := ’i is th’ 
RightStr(Dstr, 6) := ’e BEST’

 
 
8.{判断字符是否是数字} 
function IsDigit(ch: char): boolean; 
begin 
  Result := ch in ['0'..'9']; 
end; 
 
9、{判断字符是否是大写字符} 
function IsUpper(ch: char): boolean; 
begin 
  Result := ch in ['A'..'Z']; 
end; 
10、{判断字符是否是小写字符} 
function IsLower(ch: char): boolean; 
begin 
  Result := ch in ['a'..'z']; 
end; 
11、{转换为大写字符} 
function ToUpper(ch: char): char; 
begin 
  Result := chr(ord(ch) and $DF); 
end; 
12、{转换为小写字符} 
function ToLower(ch: char): char; 
begin 
  Result := chr(ord(ch) or $20); 
end; 
{ Capitalizes first letter of every word in s } 
 
function Proper(const s: string): string; 
var 
  i: Integer; 
  CapitalizeNextLetter: Boolean; 
begin 
  Result := LowerCase(s); 
  CapitalizeNextLetter := True; 
  for i := 1 to Length(Result) do 
  begin 
    if CapitalizeNextLetter and IsLower(Result[i]) then 
      Result[i] := ToUpper(Result[i]); 
    CapitalizeNextLetter := Result[i] = ' '; 
  end; 
end; 
//////////////////////////////////////////////////////////// 
13.{返回两个子字符串之间字符的个数} 
Function p2pcount( s, ss1, ss2 : string ): integer; 
var i, j, slen : integer; 
begin 
   i := pos( ss1, s ); 
   j := pos( ss2, s ); 
   slen := Length(ss2); 
   if j >= i then Result := j - i + slen else Result := 0; 
end; 
14.{更快速的字符查询,快40%} 
function ScanStr(ToScan: PChar; Sign: Char):PChar; 
begin 
  Result:= nil; 
  if ToScan <> nil then 
    while (ToScan^ <> #0) do begin 
      if ToScan^ = Sign then begin 
        Result:= ToScan; 
        break; 
       end; 
     inc(ToScan); 
    end; 
end; 
///////////////////////////// 
15.替换字符串中子串的函数,他可以从字符串中找出指定子串,并替换为另一子串。 
function replacing(S,source,target:string):string; 
var site,StrLen:integer; 
begin 
{source在S中出现的位置} 
site:=pos(source,s); 
{source的长度} 
StrLen:=length(source); 
{删除source字符串} 
delete(s,site,StrLen); 
{插入target字符串到S中} 
insert(target,s,site); 
{返回新串} 
replacing:=s; 
end; 
/////////////////////// 
另两个替换字符串中子串的函数 
function repl_substr( sub1, sub2, s: string ): string; 
var i: integer; 
begin 
   repeat 
     i := pos( sub1, s ) ; 
     if i > 0 then begin 
       delete( s, i, Length(sub1)); 
       insert( sub2, s, i ); 
     end; 
   until i < 1; 
   Result := s; 
end; 
function ReplaceText(const S,ReplacePiece,ReplaceWith: String):String; 
Var Position: Integer; 
    TempStr: String; 
begin 
  Position := Pos(ReplacePiece,S); 
  if Position > 0 then Begin 
    TempStr := S; 
    Delete(TempStr,1,Position-1+Length(ReplacePiece)); 
    Result := 
Copy(S,1,Position-1)+ReplaceWith+ReplaceText(TempStr,ReplacePiece,ReplaceWith) 
  End else Result := S; 
end; 
//////////////////////// 
替换全部子字符串的函数 
  function ReplaceSub(str, sub1, sub2: String): String; 
    var 
    aPos: Integer; 
    rslt: String; 
  begin 
    aPos := Pos(sub1, str); 
    rslt := ''; 
    while (aPos <> 0) do begin 
      rslt := rslt + Copy(str, 1, aPos - 1) + sub2; 
      Delete(str, 1, aPos + Length(sub1)); 
      aPos := Pos(sub1, str); 
    end; 
    Result := rslt + str; 
  end; 
///////////////////////// 
在字符串左右填充指定数量的指定字符 
function UT_PadString(inString :string; maxLength :integer; padChar :char; 
left :boolean) :string; 
begin 
  result := inString; 
  while (Length(result) < maxLength) do 
    if (left) then 
      result := padChar + result 
    else 
      result := result + padChar; 
end; 
///////////////////////////////////// 
提取字符串中指定子字符串前的字符串 
Function Before ( string ; Var S:string ) : string ; < /span>
  Var 
  F : Word ; 
begin 
  F := POS (Src,S) ; 
  if F=0 then 
    Before := S 
   else 
    Before := COPY(S,1,F-1) ; 
end ; 
////////////////////////////////// 
提取字符串中指定子字符串后的字符串 
Function After ( string ; Var S:string ) : string ; < /span>
  Var 
  F : Word ; 
begin 
  F := POS (Src,S) ; 
  if F=0 then 
    After := '' 
   else 
    After := COPY(S,F+length(src),length(s)) ; 
end ; 
//////////////////////////////////// 
判断字符串是否可以转换为整数 
function IsIntStr(const S: string): boolean; 
begin 
  Result:=StrToIntDef(S,0)=StrToIntDef(S,1); 
end; 
////////////////////////////////////// 
从字符串中删除指定字符串 
procedure RemoveInvalid(what, where: string): string; 
  var 
  tstr: string; 
begin 
  tstr:=where; 
  while pos(what, tstr)>0 do 
    tstr:=copy(tstr,1,pos(what,tstr)-1) + 
       copy(tstr,pos(what,tstr)+length(tstr),length(tstr)); 
  Result:=tstr; 
end; 
用法: 
  NewStr:=RemoveInvalid('<invalid>','This <invalid> is my string and I wan to 
       remove the word <invalid>'); 
/////////////////////////////////////////// 
根据某个字符分割字符串的函数 
procedure SeparateTerms(s : string;Separator : char;Terms : TStringList); 
{ This browses a string and divide it into terms whenever the given 
  separator is found. The separators will be removed } 
  var 
  hs : string; 
  p : integer; 
begin 
  Terms.Clear; // First remove all remaining terms 
  if Length(s)=0 then   // Nothin' to separate 
    Exit; 
  p:=Pos(Separator,s); 
  while P<>0 do 
  begin 
    hs:=Copy(s,1,p-1);   // Copy term 
    Terms.Add(hs);       // Add to list 
    Delete(s,1,p);       // Remove term and separator 
    p:=Pos(Separator,s); // Search next separator 
  end; 
  if Length(s)>0 then 
    Terms.Add(s);        // Add remaining term 
end; 
========== 
= 用  法 
========== 
var 
Terms : TStringList; 
i : integer; 
const 
TestStr = '1st term;2nd term;3rd term'; 
begin 
  Terms:=TStringList.Create; 
  SeparateTerms(TestStr,';',Terms); 
  for i:=0 to terms.Count-1 do 
    ShowMessage(Terms.Strings[i]); 
  Terms.Free; 
end; 
///////////////////////////// 
根据一组字符分割字符串的函数 
type 
 Charset = set of Char; 
var 
 f : Text; 
 s : String; 
procedure WriteStringSplitted(var s: String; Separators: Charset); 
var 
 a,e : Integer;  {anfang und ende des w鰎tchens} 
begin 
 a := 1; 
 for e := 1 to Length(s) do 
  if s[e] in Separators then begin 
   WriteLn(Copy(s, a, e-a)); 
   a := e + 1; 
  end; 
  WriteLn(Copy(s, a, e-a+1)); 
end; 
begin 
 Assign(f, 'c:/dingsbums/text.txt'); 
 Reset(f); 
 while not EOF(f) do begin 
  ReadLn(f,s); 
  WriteStringSplitted(s, [':', ',']); 
 end; 
 Close(f); 
end. 
////////////////////////////////////////////////// 
{===============================================================} 
{ 函数  : RESULTSTRING = HexToBin(HEXSTRING) 
{ 目的   : 把十六进制字符串转换为二进制字符串 

{===============================================================} 
{ 函数  : RESULTINTEGER = HexCharToInt(HEXCHAR) 
{ 目的   : 转换一个十六进制字符为整数 
{===============================================================} 
{ 函数  : RESULTSTRING = HexCharToBin(HEXCHAR) 
{ 目的   : 转换一个十六进制字符为二进制字符串 
{===============================================================} 
{ 函数  : RESULTINTEGER = Pow(BASE,POWER) 
{ 目的   : 指数函数 
{===============================================================} 
{ 函数  : RESULTINTEGER = BinStrToInt(BINSTRING) 
{ 目的   : 把二进制字符串转换为整数 
{===============================================================} 
{ 函数  : RESULTSTRING = DecodeSMS7Bit (PDUSTRING) 
{ 目的   : 解码一个7-bit SMS (GSM 03.38) 为ASCII码 
{===============================================================} 
{ 函数  :  RESULTSTRING = ReverseStr (SOURCESTRING) 
{ 目的   : 反转一个字符串 
{===============================================================} 
unit BinHexTools; 
interface 
function HexToBin(HexNr : string): string; 
function HexCharToInt(HexToken : char):Integer; 
function HexCharToBin(HexToken : char): string; 
function pow(base, power: integer): integer; 
function BinStrToInt(BinStr : string) : integer; 
function DecodeSMS7Bit(PDU : string):string; 
function ReverseStr(SourceStr : string) : string; 
implementation 
uses sysutils, dialogs; 
function HexCharToInt(HexToken : char):Integer; 
begin 
  {if HexToken>#97 then HexToken:=Chr(Ord(HexToken)-32); 
  { use lowercase aswell } 
  Result:=0; 
  if (HexToken>#47) and (HexToken<#58) then       { chars 0....9 } 
     Result:=Ord(HexToken)-48 
  else if (HexToken>#64) and (HexToken<#71) then  { chars A....F } 
     Result:=Ord(HexToken)-65 + 10; 
end; 
function HexCharToBin(HexToken : char): string; 
var DivLeft : integer; 
begin 
    DivLeft:=HexCharToInt(HexToken);   { first HEX->BIN } 
    Result:=''; 
                                       { Use reverse dividing } 
    repeat                             { Trick; divide by 2 } 
      if odd(DivLeft) then             { result = odd ? then bit = 1 } 
        Result:='1'+Result             { result = even ? then bit = 0 } 
      else 
        Result:='0'+Result; 
      DivLeft:=DivLeft div 2;       { keep dividing till 0 left and length = 4 } 
    until (DivLeft=0) and (length(Result)=4);      { 1 token = nibble = 4 bits } 
end; 
function HexToBin(HexNr : string): string; 
{ only stringsize is limit of binnr } 
var Counter : integer; 
begin 
  Result:=''; 
  for Counter:=1 to length(HexNr) do 
    Result:=Result+HexCharToBin(HexNr[Counter]); 
end; 
function pow(base, power: integer): integer; 
var counter : integer; 
begin 
  Result:=1; 
  for counter:=1 to power do 
    Result:=Result*base; 
end; 
function BinStrToInt(BinStr : string) : integer; 
var counter : integer; 
begin 
  if length(BinStr)>16 then 
    raise ERangeError.Create(#13+BinStr+#13+ 
            'is not within the valid range of a 16 bit binary.'+#13); 
  Result:=0; 
  for counter:=1 to length(BinStr) do 
      if BinStr[Counter]='1' then 
        Result:=Result+pow(2,length(BinStr)-counter); 
end; 
function DecodeSMS7Bit(PDU : string):string; 
var OctetStr : string; 
    OctetBin : string; 
    Charbin  : string; 
    PrevOctet: string; 
    Counter  : integer; 
    Counter2 : integer; 
begin 
  PrevOctet:=''; 
  Result:=''; 
  for Counter:=1 to length(PDU) do 
    begin 
      if length(PrevOctet)>=7 then     { if 7 Bit overflow on previous } 
        begin 
          if BinStrToInt(PrevOctet)<>0 then 
            Result:=Result+Chr(BinStrToInt(PrevOctet)) 
          else Result:=Result+' '; 
          PrevOctet:=''; 
        end; 
      if Odd(Counter) then            { only take two nibbles at a time } 
        begin 
          OctetStr:=Copy(PDU,Counter,2); 
          OctetBin:=HexToBin(OctetStr); 
          Charbin:=''; 
          for Counter2:=1 to length(PrevOctet) do 
            Charbin:=Charbin+PrevOctet[Counter2]; 
          for Counter2:=1 to 7-length(PrevOctet) do 
            Charbin:=OctetBin[8-Counter2+1]+Charbin; 
          if BinStrToInt(Charbin)<>0 then Result:=Result+Chr(BinStrToInt(CharBin)) 
            else Result:=Result+' '; 
          PrevOctet:=Copy(OctetBin,1,length(PrevOctet)+1); 
        end; 
    end; 
end; 
function ReverseStr(SourceStr : string) : string; 
var Counter : integer; 
begin 
  Result:=''; 
  for Counter:=1 to length(SourceStr) do 
    Result:=SourceStr[Counter]+Result; 
end; 
end. 
读完这篇文章后,您心情如何?
0
0
0
0
0
0
0
0
本文网址: