CODESYS读取csv文件的方法(非excel)

1、序言

       CSV是一种通用的、相对简单的文件格式,被用户、商业和科学广泛应用。最广泛的应用是在程序之间转移表格数据,而这些程序本身是在不兼容的格式上进行操作的(往往是私有的和/或无规范的格式)。因为大量程序都支持某种CSV变体,至少是作为一种可选择的输入/输出格式。 如果你的机器上装了 Microsoft Excel的话,.csv 文件默认是被Excel打开的。

codesys具有文件打开,文件读取,文件写入的功能块和库,那么csv格式的文件能否在codesys中打开呢,答案是显而易见的,接下来我们就来介绍下具体的操作方法。

2、CSV数据格式

        逗号分隔值(Comma-Separated Values,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。纯文本意味着该文件是一个字符序列,不含必须像二进制数字那样被解读的数据。CSV文件由任意数目记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符

      我们以一个文件数据为例来说明:用EXCEL打开DATA.CSV文件,看到如下数据:

我们可以用记事本模式打开,可以看到如下内容:

 通过对比我们可以发现,本例中的CSV的数据通过“,”隔开,空白的地方没有数据,同时需要注意的是第二行与第一行之间存在换行符,记事本也显示不出来,但总体我们可以把CSV数据看作是一串字符序列。

 3、文件读取功能块

3.1、文件读取功能块

codesys读取文件需要添加4个库文件,本例使用codesys软件版本为V3.5.14.10:

a、SysFile, 3.5.15.0(System):该库提供访问文件的功能
b、SysTypes2 Interfaces, 3.5.4.0(System):该库提供访问文件的数据格式
c、Util, 3.5.15.0(System):该库提供数据类型转换
d、StringUtils, 3.5.15.0(System): 该库包含处理字符串的函数

库文件添加方式这里不做介绍。

3.2、功能块指令介绍

文件读取功能主要用到 SysFileOpen,SysFileGetSizeByHandle,SysFileRead,SysFileGetPos,SysFileClose五个指令,功能作用分别如下:

 3.3、CSV读取基本流程

CSV文件读取的步骤如下:

a、通过SysFileOpen指令打开文件;

b、通过SysFileGetSizeByHandle获取文件字符序列大小;

c、通过SysFileRead读取一次读取字符序列,并按顺序依次存入预先设好的数组中;

d、通过SysFileGetPos获取文件指针位置,判断是否读取了所有数据;

e、通过SysFileClose关闭CSV文件,若文件不关闭,则下次无法读取。

f、数组数据处理。

4、程序编写

本例通过ST语言编写

4.1、创建变量

变量表创建如下:文件路径根据实际情况设置,路径中不能包含中文,否则无法识别!!。

 4.2、程序编写

a、读取文件数据

 b、数据处理

通过SysFileRead指令读取出来的CSV字符序列的原始数据为ASCII码值,需要通过转换,再进行合并处理,需要避开"逗号","回车和换行",并需要通过"逗号","回车和换行"来确定对应数据的具体位置,篇幅限制,不做详细解释,数据处理程序如下:

 

4.3、创建可视化视图

使用多个文本框建立与数据对应的表格,并通过文本变量与数组连接,单按钮控制,视图如下:

 变量连接如下:

 

 4.4、运行结果

通过仿真运行我们先查看原始数据,可以通过对应ASCII码表与原数据进行对比,结果如下:

 通过ascii对比验证可以得出,读取的数据没有问题。

再来验证数据转换后与表格数据的对应,仿真结果如下:

codesys读取csv文件的视频演示

 5、综述

通过以上分析,程序编写及验证,codesys通过文件读取功能块是完全可以实现对CSV文件数据的读取,下一篇文章将对写入功能进行探讨。

需要注意的是:

1、读取CSV时,我们发现需要将所有数据读取出来,通过"逗号"、"换行"、"回车"等符号才能确定所有数据的对应位置,因此即使我们仅仅需要其中的一个数据,也需要将所有数据读出。

2、而当数据量大的时候,我们建立的读取数组也需要有对应的容量来存储,否则就会丢失数据。本例中数据量较小,不超过50个,所以并无影响。

本文所采用的codesys版本为V3.5.14.10,所涉及的程序可通过以下地址下载:

https://download.csdn.net/download/qq_19979629/85196575

      

CODESYS是一种针对嵌入式系统的开发平台,它提供了一系列的编程工具和功能,用于开发和管理嵌入式应用程序。CSV是一种常用的文件格式,用于存储和交换数据。在CODESYS中,CSV文件经常用于导入和导出数据。 CODESYS平台提供了用于处理CSV文件的库和函数。使用这些工具,我们可以轻松地从CSV文件读取数据,并将数据保存到CSV文件中。在读取CSV文件时,我们可以逐行读取文件内容,并将每行数据拆分成不同的字段。然后,我们可以使用这些字段来进行后续的数据处理和分析。同样,在将数据保存到CSV文件时,我们可以将数据分为不同的字段,并将这些字段按照CSV文件格式保存到文件中。 除了读写CSV文件外,CODESYS还提供了一些其他的CSV相关功能。例如,我们可以使用CODESYS动态创建和编辑CSV文件,包括添加、修改和删除数据行和字段。我们还可以对CSV文件进行排序、过滤和查询,以满足不同的数据处理需求。此外,CODESYS还支持将CSV文件与其他数据源进行集成,例如数据库和Web服务,以实现数据的交换和共享。 总之,CODESYS提供了强大和灵活的功能,让开发者可以方便地处理和管理CSV文件。通过使用CODESYSCSV库和函数,我们可以轻松地导入、导出、读取、写入和处理CSV文件中的数据,从而满足各种数据处理和分析的需求。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tnt1314

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值