一些小笔记(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文件的过程中。那么它就可以保存之前的历史值,并将值带入下一次循环。

相关推荐
知识分享小能手7 分钟前
Oracle 19c入门学习教程,从入门到精通,PL/SQL 编程详解:语法、使用方法与综合案例(6)
sql·学习·oracle
richxu2025100110 分钟前
嵌入式学习之路->stm32篇-->(8)I2C通讯(上)
stm32·嵌入式硬件·学习
行业探路者16 分钟前
如何利用二维码提升富媒体展示的效果?
大数据·人工智能·学习·产品运营·软件工程
中屹指纹浏览器17 分钟前
指纹浏览器网络隔离与泄漏防护技术全解析——从架构设计到落地实践摘要
经验分享·笔记
生擒小朵拉27 分钟前
ROS1学习笔记(一)
笔记·学习
丝斯201127 分钟前
AI学习笔记整理(52)——大模型之Agent 智能体
人工智能·笔记·学习
lpfasd12337 分钟前
《开发者技术及生态发展2030》研读报告
笔记·程序人生
小范馆42 分钟前
ESP8266-01S学习笔记
笔记·stm32·学习·esp8266-01s
jimmyleeee1 小时前
人工智能基础知识笔记三十四:提升RAG效果的几种技术
人工智能·笔记
sweetone1 小时前
反用高通滤波电路提升低频的实例
经验分享·音视频