- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近发现了这段代码,我一直在尝试修改它,但没有运气。我如何修改代码,以便它不仅接受文件,还接受 TStrings?
只能这样使用
TMultiStringList.LoadFromFile('somefile.txt',
TMultiStringList.TFill.mfiClearBeforeFill,
TMultiStringList.TMode.mslSpread);
但不是这样的
TMultiStringList.LoadFromStrings(StringList.Text,
TMultiStringList.TFill.mfiClearBeforeFill,
TMultiStringList.TMode.mslSpread);
来源:
unit Multi;
interface
uses
System.SysUtils,
System.Classes,
System.Generics.Collections;
type
TMultiStringList = class
public
type
TFill = (mfiAdd, mfiClearBeforeFill);
TMode = (
mslTrim, // Trim lines before add
mslLower, // Lower lines before add
mslUpper, // Upper lines before add
mslAssign, // Just use Assign()
mslSpread); // Spread text to the lists
private
FLength: Integer;
FLists: TArray<TStringList>;
function ValidArray(): Boolean;
procedure BuildArray(const Length: Integer);
procedure FreeArray();
function GetList(const Index: Integer): TStringList;
public
constructor Create(const Length: Integer);
destructor Destroy(); override;
procedure LoadFromFile(const FileName: string; const Fill: TFill; const Mode: TMode);
property ListCount: Integer read FLength;
property Lists[const Index: Integer]: TStringList read GetList;
end;
implementation
{ TMultiStringList }
procedure TMultiStringList.BuildArray(const Length: Integer);
var
I: Integer;
begin
SetLength(FLists, Length);
for I := Low(FLists) to High(FLists) do
FLists[I] := TStringList.Create();
end;
constructor TMultiStringList.Create(const Length: Integer);
begin
FLength := Length;
BuildArray(Length);
end;
destructor TMultiStringList.Destroy;
begin
FreeArray();
inherited;
end;
procedure TMultiStringList.FreeArray;
var
I: Integer;
begin
if (Length(FLists) > 0) then
begin
for I := Low(FLists) to High(FLists) do
begin
FLists[I].Free();
FLists[I] := nil;
end;
SetLength(FLists, 0);
end;
end;
function TMultiStringList.GetList(const Index: Integer): TStringList;
begin
Result := FLists[Index];
end;
procedure TMultiStringList.LoadFromFile(const FileName: string; const Fill: TFill; const Mode: TMode);
procedure HandleLoad(Callback: TProc<TStringList, string>);
var
List, Target: TStringList;
I, J: Integer;
begin
List := TStringList.Create();
try
List.LoadFromFile(FileName);
for I := Low(FLists) to High(FLists) do
begin
if (Fill = TFill.mfiClearBeforeFill) then
FLists[I].Clear();
for J := 0 to List.Count - 1 do
Callback(FLists[I], List[J]);
end;
finally
List.Free();
end;
end;
procedure HandleAssign();
var
I: Integer;
begin
if (Fill = TFill.mfiClearBeforeFill) then
FLists[0].Clear();
FLists[0].LoadFromFile(FileName);
for I := 1 to High(FLists) do
begin
if (Fill = TFill.mfiClearBeforeFill) then
FLists[I].Clear();
FLists[I].Assign(FLists[0]);
end;
end;
procedure HandleSpread();
var
List: TStringList;
I: Integer;
ItemsPerList: Integer;
ListIndex: Integer;
begin
if (Fill = TFill.mfiClearBeforeFill) then
begin
for I := Low(FLists) to High(FLists) do
FLists[I].Clear();
end;
List := TStringList.Create();
try
List.LoadFromFile(FileName);
ItemsPerList := (List.Count + FLength - 1) div FLength;
for I := 0 to List.Count - 1 do
begin
FLists[I div ItemsPerList].Add(List[I]);
end;
finally
List.Free();
end;
end;
begin
if (not ValidArray()) then
raise Exception.Create('Array incomplete!');
case Mode of
mslTrim : HandleLoad(
procedure(Target: TStringList; S: string)
begin
Target.Add(Trim(S));
end);
mslLower : HandleLoad(
procedure(Target: TStringList; S: string)
begin
Target.Add(LowerCase(S));
end);
mslUpper : HandleLoad(
procedure(Target: TStringList; S: string)
begin
Target.Add(UpperCase(S));
end);
mslAssign : HandleAssign();
mslSpread : HandleSpread();
else
raise ENotImplemented.Create('Mode not implemented!');
end;
end;
function TMultiStringList.ValidArray: Boolean;
begin
Result := Length(FLists) = FLength;
end;
end.
最佳答案
也许像这样?
procedure TMultiStringList.LoadFromFile(const FileName: string; const Fill: TFill; const Mode: TMode);
var
list: TStringList;
begin
list := TStringList.Create;
try
list.LoadFromFile(FileName);
LoadFromStrings(list, Fill, Mode);
finally
list.Free;
end;
end;
procedure TMultiStringList.LoadFromStrings(Source: TStrings; const Fill: TFill; const Mode: TMode);
procedure HandleLoad(Callback: TProc<TStringList, string>);
var
list: TStringList;
line: string;
begin
for list in FLists do
begin
if (Fill = TFill.mfiClearBeforeFill) then
list.Clear();
for line in Source do
Callback(list, line);
end;
end;
procedure HandleAssign();
var
I: Integer;
begin
if (Fill = TFill.mfiClearBeforeFill) then
FLists[0].Clear();
FLists[0].AddStrings(Source);
for I := 1 to High(FLists) do
begin
if (Fill = TFill.mfiClearBeforeFill) then
FLists[I].Clear();
FLists[I].Assign(FLists[0]);
end;
end;
procedure HandleSpread();
var
list: TStringList;
I: Integer;
ItemsPerList: Integer;
begin
if (Fill = TFill.mfiClearBeforeFill) then
begin
for list in FLists do
list.Clear();
end;
ItemsPerList := (Source.Count + FLength - 1) div FLength;
for I := 0 to Source.Count - 1 do
begin
FLists[I div ItemsPerList].Add(Source[I]);
end;
end;
begin
if (not ValidArray()) then
raise Exception.Create('Array incomplete!');
case Mode of
mslTrim : HandleLoad(
procedure(Target: TStringList; S: string)
begin
Target.Add(Trim(S));
end);
mslLower : HandleLoad(
procedure(Target: TStringList; S: string)
begin
Target.Add(LowerCase(S));
end);
mslUpper : HandleLoad(
procedure(Target: TStringList; S: string)
begin
Target.Add(UpperCase(S));
end);
mslAssign : HandleAssign();
mslSpread : HandleSpread();
else
raise ENotImplemented.Create('Mode not implemented!');
end;
end;
关于delphi - TMultiStringList 和 TString,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13914756/
基本上我有(州,州代码)对,它们是国家的子集[美国] -> [VT] -> 32 所以我正在使用 std::map>但是我在分配州代码时遇到了问题 for(std::map>::const_itera
如何检查 TStrings 中是否存在特定字符串?例如,我有包含大量文本的 TString,我想检查字符串是否为“Hello!”出现在本文中。 “你好!”只是一个示例字符串。它可以是任何东西。字符串可
我有一个从 TFrame 扩展的对象。这包含一个 TCombobox。 我想确保当我的框架被破坏时释放任何关联的对象。然而,当我的析构函数运行时,我可以访问组合框,但它的项目已被清除。 这会做什么?我
我最近发现了这段代码,我一直在尝试修改它,但没有运气。我如何修改代码,以便它不仅接受文件,还接受 TStrings? 只能这样使用 TMultiStringList.LoadFromFile('som
我编写了一个类似 TListBox 的控件(类似于 Doctor Bob's SpeedBox )。 它运行良好,但有一个问题除外:分配给属性 Items 的字符串在启动时不会加载到 TListBox
我需要搜索一大组数据文件。我想查找包含字符串“foo\tbar\tboo”的文件。我试过这个... $ find . -name "foo*dat" -exec grep foo {} \; | le
我在尝试为自己输入一个方便的 tstring 时遇到问题(见下文) #ifndef _NISAMPLECLIENT_H_ #define _NISAMPLECLIENT_H_ #include #i
以下代码有效: var SL: TStrings; begin SL := TStringList.Create; try SL.Add(Format('%s=%s', ['Ale
我有一个文件.\input.txt,如下所示: aaa bbb ccc 如果我使用 TStrings.LoadFromFile 阅读它并使用 TStrings.SaveToFile 将其写回(即使不应
为什么变量声明为 TStrings 并创建为 TStringList? 例如:var sl 被声明为 TStrings 但创建为 TStringList var sl : TStrings; be
在 Delphi XE7 中,我使用 Anders Melander 著名的 DragAndDropSuite。该套件中的 TDropFileTarget 组件将删除的文件作为 TUnicodeStr
好吧,这变得很傻了...... 这是第二次(第一次是在 30 分钟前,在一个获取目录树的函数上)我曾经看到错误“抽象错误”,真的不知道为什么会发生。 我有这个功能,列出所有的硬盘: function
在 Delphi 7 中,我使用 TCheckListBox。我希望它使用 TStringList 而不是 TStrings,因此我可以将重复项设置为 dupIgnore,并将排序设置为 TRUE。
有人可以帮我解释为什么当底层函数中引发异常时 TStrings 会作为“不可访问的值”返回吗? function GetStrings():TStrings; begin result := TS
我正在尝试将 LPTSTR 变量转换为 tstring(即,unicode 应用程序中的 wstring 和 ANSI 中的字符串)。 我如何执行此转换? 我的代码尝试执行转换,但它导致错误:“调试断
Delphi XE在Encoding类中添加了TStrings属性,该属性存储在调用LoadFromFile()时从BOM表读取的编码。 Delphi 2010没有此属性。 我想效仿它。 我为TStr
我有字符串'AAA'+#$0d+#$0a+'BBB'+#$01d+'CCC'。我需要根据 #$1d 字符进行分割,例如: 'AAA'+#$0d+#$0a+'BBB' 'CCC' 我正在使用函数: pr
我在 WCP 1252 编码的头文件中有一个字符串: #define MY_STR "This string has some fancy characters like ©" 我如何使用像 UTF-
我饶有兴趣地阅读了 Nick Hodges 的博客 Why You Should Be Using Interfaces由于我已经爱上了编码中更高级别的接口(interface),因此我决定研究如何将
为什么Memo.Lines使用抽象类TStrings?为什么不使用 TStringList 来代替? 我应该在使用它之前将其转换为 TStringList 吗? 最佳答案 TMemo.Lines、TL
我是一名优秀的程序员,十分优秀!