一些小笔记(Delphi)

工具:Delphi10.4

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

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

我的解决办法如下:

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

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

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

Delphi 复制代码
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文件的过程中。那么它就可以保存之前的历史值,并将值带入下一次循环。

相关推荐
大布布将军1 小时前
⚡️ 深入数据之海:SQL 基础与 ORM 的应用
前端·数据库·经验分享·sql·程序人生·面试·改行学it
专注于大数据技术栈1 小时前
java学习--StringBuilder
java·学习
锦瑟弦音1 小时前
微信小游戏分包(cocos自带分包)
笔记·游戏
找方案2 小时前
我的 all-in-rag 学习笔记:文本分块 ——RAG 系统的 “信息切菜术“
人工智能·笔记·all-in-rag
HXR_plume2 小时前
【Web信息处理与应用课程笔记1】网页排序(上)
笔记
源代码•宸2 小时前
goframe框架签到系统项目(BITFIELD 命令详解、Redis Key 设计、goframe 框架教程、安装MySQL)
开发语言·数据库·经验分享·redis·后端·mysql·golang
qcwl662 小时前
操作系统 真象还原 学习笔记#13
笔记·学习
车载测试工程师2 小时前
CAPL学习-CAN相关函数-概述
网络协议·学习·capl·canoe
roman_日积跬步-终至千里2 小时前
【人工智能导论】08-学习-如何让计算机理解序列数据——用RNN/LSTM建模时序依赖,用文本嵌入表示序列元素
人工智能·rnn·学习
m0_689618282 小时前
30 分钟打印!多材料3D打印软机器人内置驱动 + 自主避障
笔记·学习·机器人