一些小笔记(Delphi)

工具:Delphi10.4

用Delphi写了一个解析json文件的小程序,

需求是能解析整个文件夹中的所有文件,也能只解析某一个文件,文件或者文件夹的路径能够直接填写,也能够通过选择的方式去填充。

我的解决办法如下:

1.先用下面的代码进行目录的选择或输入,可以自己定义默认选择的目录,我写的默认是空

var
  vPath: string;
begin
  //默认选择的目录
  vPath := '';
  //显示列表的根目录,空时显示全部
  //sdNewUI  可调整大小,显示右键菜单
  //sdNewFolder 显示“新建文件夹”按钮
  //sdShowEdit 显示“文件夹”输入框
  //sdValidateDir  验证插入编辑框中的文件夹/文件的名称
  SelectDirectory('弹出的标题', '', vPath, [sdNewUI, sdNewFolder, sdShowEdit, sdValidateDir], Self);
  EditFilePath.Text:=vPath;
end;

2.遍历文件夹获取文件名并用列表返回

var
  SearchRec: TSearchRec;
begin
  Result := TStringList.Create;
  //FindFirst函数寻找目标目录下的第一个文件,成功返回0; faAnyFile参数表示任意文件(所有文件)
  if FindFirst(FolderPath + '\*', faAnyFile, SearchRec) = 0 then
  begin
    repeat
      //SearchRec.Name取文件名
      if (SearchRec.Name <> '.') and (SearchRec.Name <> '..') then
        Result.Add(FolderPath + '\' + SearchRec.Name);
    until FindNext(SearchRec) <> 0;
    FindClose(SearchRec);
  end;
end;

3.用if...else if...else,

  • 先用DirectoryExists(Path)判断目录路径是否存在,其中Path是自己输入的路径,如果存在那么遍历之前返回的文件列表获取文件名,一个文件一个文件地去解析文件夹下对应的文件;
  • 如果不是那么用FileExists(Path);判断文件路径是否存在,如果存在那么解析对应文件,
  • 如果不存在那么给出提示信息'文件路径不存在'

另一个问题

就是我解析到的数据是需要插入到数据库表中的,但是有一个要求是:当解析的是文件夹且文件夹中包含有多个文件的时候,数据要么全部插入成功,要么全部插入失败,不能有的文件中的数据插入成功,而有的文件中的数据插入失败。那么在遍历的时候写的sql语句是需要全部一起执行的,可以用Tstringlist来存储sql语句,并且将其作为参数,以传址的方式传入解析json文件的过程中。那么它就可以保存之前的历史值,并将值带入下一次循环。

你可能感兴趣的:(学习,笔记,经验分享,其他)