lazarus:不安装任何驱动,直接使用csv文件作为数据集

2023-11-07 12:52

本文主要是介绍lazarus:不安装任何驱动,直接使用csv文件作为数据集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1 简介

2 需要的窗体控件很简单

3 定义字段并插入几条记录

4 其他操作

4.1 数据集保存为csv文件

4.2 清空数据

4.3 加载csv文件

5 运行程序

6 导出文件


1 简介

在某些数据操作需求特别简单的情况下,我们希望不要安装任何数据库,甚至连一个驱动dll都不要,因为这些驱动dll可能涉及到版本甚至跨平台问题。这种简单需求,可以直接使用csv文件作为数据集来进行增查删改操作。注意,这不是用某些数据库映射csv文件作为数据库的一个表。

这种直接操作csv文件数据集好处不少,比如不用安装任何驱动,支持跨平台,可以直接使用文本编辑器修改文件,体积极小容易发布等。当然Lazarus还有其他可用的类似方式,比如直接操作电子表格文件、dbf文件等,都不需要安装驱动,都可以实现增查删改功能。

这里简单介绍把csv映射为数据集以及相关的简单操作。

2 需要的窗体控件很简单

核心控件就是这个 CSVDataset,位于控件集的Data Access页签中。

3 定义字段并插入几条记录

在FormCreate事件中,检查是否存在指定名称的csv文件,如果存在就直接加载。如果不存在,则定义字段信息,然后用代码插入几条记录:

procedure TForm1.FormCreate(Sender: TObject);
beginCSVDataset1.FileName := Application.Location + FILENAME;CSVDataset1.CSVOptions.FirstLineAsFieldNames := true;// 程序首次运行,数据文件不存在.// 必须创建字段信息.建立数据集。if not FileExists(CSVDataset1.FileName) then beginwith CSVDataset1 do beginFieldDefs.Add('FirstName', ftString, 20);FieldDefs.Add('LastName', ftstring, 20);FieldDefs.Add('City', ftString, 20);FieldDefs.Add('Address', ftString, 30);FieldDefs.Add('Birthdate', ftDate);CreateDataset;// 打开数据集...Open;// ... 增加数据:Append;FieldByName('FirstName').AsString := 'Walter';FieldByName('LastName').AsString := 'Mellon';FieldByName('City').AsString := 'Oklahoma City';FieldByName('Address').AsString :=  '1261, Main Street';FieldbyName('Birthdate').AsDateTime := EncodeDate(1980, 1, 1);Post;Append;FieldByName('FirstName').AsString := 'Mario';FieldByName('LastName').AsString := 'Speedwagon';FieldByName('City').AsString := 'Hollywood';FieldByName('Address').AsString :=  '1500, Hollywood Blvd';FieldbyName('Birthdate').AsDateTime := EncodeDate(1982, 12, 17);Post;Append;FieldByName('FirstName').AsString := 'Anna';FieldByName('LastName').AsString := 'Mull';FieldByName('City').AsString := 'Los Angeles';FieldByName('Address').AsString :=  '2202, Capitol Square';FieldbyName('Birthdate').AsDateTime := EncodeDate(1982, 12, 17);Post;end;end;CSVDataset1.Open;
end;  

4 其他操作

4.1 数据集保存为csv文件

procedure TForm1.Button1Click(Sender: TObject);
beginCSVDataset1.SaveToCSVFile('exported.csv');
end; 

4.2 清空数据

procedure TForm1.Button2Click(Sender: TObject);
beginCSVDataset1.Clear;
end; 

4.3 加载csv文件

procedure TForm1.Button3Click(Sender: TObject);
beginCSVDataset1.LoadFromCSVFile('exported.csv');
end; 

5 运行程序

6 导出文件

导出的csv文件如果有中文,需要以utf8格式查看。

这篇关于lazarus:不安装任何驱动,直接使用csv文件作为数据集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/363748

相关文章

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

电脑软件不能安装到C盘? 真相颠覆你的认知!

《电脑软件不能安装到C盘?真相颠覆你的认知!》很多人习惯把软件装到D盘、E盘,刻意绕开C盘,这种习惯从哪来?让我们用数据和案例,拆解背后的3大原因... 我身边不少朋友,在使用电脑安装软件的时候,总是习惯性的把软件安装到D盘或者E盘等位置,刻意避开C盘。如果你也有这样的习惯,或者不明白为什么要这么做,那么我

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写