procedure StrToStrings(S: AnsiString; Sep: AnsiString; const List: TStrings);
var
I, L: Integer;
Left: AnsiString;
begin
Assert(List <> nil);
List.Clear;
L := Length(Sep);
I := Pos(Sep, S);
while (I > 0) do
begin
Left := LeftStr(S, I - 1);
List.Add(Left);
Delete(S, 1, I + L - 1);
I := Pos(Sep, S);
end;
if S <> '' then
List.Add(S);
end;
var
I, L: Integer;
Left: AnsiString;
begin
Assert(List <> nil);
List.Clear;
L := Length(Sep);
I := Pos(Sep, S);
while (I > 0) do
begin
Left := LeftStr(S, I - 1);
List.Add(Left);
Delete(S, 1, I + L - 1);
I := Pos(Sep, S);
end;
if S <> '' then
List.Add(S);
end;
解决方案 »
- BCB调用DLL出错,求高手解答
- 有关JPEG2000和小波算法
- 关于C/S模式的一些疑惑???????????????????????????????????????????
- 实现点击ComboBox(DBComboBox)按钮下拉出现TreeView效果?
- 求助:fastreport预览和打印问题
- 下面的代码有什么错误?
- 请帮我读取pdb格式文件中的数据
- 不好意思,问问关于ado和xml(就是LoadFromFile)
- 新年快乐,向您请教,regsvr32 XXX.DLL时提示"loadlibrary没有XXX.DLL失败,找不到指定的模块"
- fastreport的一个简单问题,你可不能错过的,如何定义变量aft_st_sd(浪子)请进
- 为什么TQuery控件的RecNo属性老是-1阿?
- 急!!读取二进制文件的问题。
list: TStringList;
begin
list := TStringList.Create;
list.Text := WrapText('The rain in Spain falls mainly on the plain.', #13#10, [' '], 45);
....
list[0]->The
list[1]->rain
....
list.Free;
end;
//返回指定的两个子串之间的字符串如输入'【9999】','【','】'输出'9999'************
//==============================================================================
function InterStr(Str,HeadStr,TailStr: string): string;
begin
Result := Copy(Str, AnsiPos(HeadStr,Str)+Length(HeadStr), AnsiPos(TailStr,Str)-AnsiPos(HeadStr,Str)-Length(HeadStr));
end;
list: TStringList;
begin
list := TStringList.Create;
list.commatext:=s;//s是你要分割的字符串
end;
list[0],list[1]...就是你想得到的分割后的字符串
2、利用copy()函数,看了其参数,你就会很容易解决了!