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文件的方法(非excel)相关推荐

  1. python读取csv文件的方法-CSV文件在Python中的几种处理方式

    Comma Separated Values,简称CSV,它是一种以逗号分隔数值的文件类型.在数据库或电子表格中,它是最常见的导入导出格式,它以一种简单而明了的方式存储和共享数据,CSV文件通常以纯文 ...

  2. python读取csv文件的方法-python读写csv文件的方法

    1.爬取豆瓣top250书籍 import requests import json import csv from bs4 import BeautifulSoup books = [] def b ...

  3. python读取csv文件的方法-python读取csv文件指定行的2种方法详解

    csv是Comma-Separated Values的缩写,是用文本文件形式储存的表格数据,比如如下的表格 就可以存储为csv文件,文件内容是: No.,Name,Age,Score 1,Apple, ...

  4. 记录python读取csv文件

    记录一下python读取文件 在做对比实验的过程当中,往往会遇到很多需要从.csv文件中读取数据的情况,因为做深度学习用的是python,所以下面记录一下使用python读取.csv文件的方法. 读取 ...

  5. php直接读取csv文件,php怎么读取csv文件?

    php读取csv文件的方法:1.使用fopen()打开csv文件:2.使用fgetcsv()从文件指针中读入一行并解析 CSV字段:3.借助循环语句,将fgetcsv()读取的csv数据存入数组中:4 ...

  6. 小练习 通过csv模块读取csv文件

    主要是讲我写代码的时候,出现的几处小错误 import csvdef csv_read():with open("student.csv") as f:readers = csv. ...

  7. python怎么读取csv文件-python读写csv文件方法详细总结

    python提供了大量的库,可以非常方便的进行各种操作,现在把python中实现读写csv文件的方法使用程序的方式呈现出来. 在编写python程序的时候需要csv模块或者pandas模块,其中csv ...

  8. python 批量读取csv_Python Pandas批量读取csv文件到dataframe的方法

    PYTHON Pandas批量读取csv文件到DATAFRAME 首先使用glob.glob获得文件路径.然后定义一个列表,读取文件后再使用concat合并读取到的数据. #读取数据 import p ...

  9. python打开csv文件设定分隔符_Python读取csv文件分隔符设置方法

    Windows下的分隔符默认的是逗号,而MAC的分隔符是分号.拿到一份用分号分割的CSV文件,在Win下是无法正确读取的,因为CSV模块默认调用的是Excel的规则. 所以我们在读取文件的时候需要添加 ...

最新文章

  1. BPSK、QPSK、MPSK、QAM、16QAM的调制解调Matlab实现
  2. java连服务器mysql报错_tomcat程序连接服务器mysql数据库报错
  3. 作为初学者应该如何来学习FPGA
  4. 动态内存分配到底为谁分配内存空间【浅谈动态内存的一个实例】
  5. DropDownList实现无限级分类
  6. 数据集市的建立方法_在集市上工作时如何建立专业网络
  7. 土拍熔断意味着什么_火爆!楼面价14615元/㎡,土拍过后房价涨,常州买房正当时!...
  8. 首都富版本更新说明文档
  9. 视频抠图在线工具有哪些?推荐这3款AI智能抠图工具
  10. android HierachyViewer使用
  11. PS打不开webp格式图片的解决方法
  12. mysqldump: Got error: 145:
  13. 阿里云ECS添加公网IPV6
  14. AutoCAD正版软件多少钱?企业应该采购多少license?
  15. 如何修改PyCharm窗口背景颜色?
  16. Google Earth Engine(GEE)——将shp文件导出到Google硬盘中
  17. 《互联网+流通——F2R助力传统产业创新与转型》一一1.1 “互联网+”的本质、演进与发展趋势...
  18. Vscode 设置clang-format
  19. OPNET计算机网络仿真 实验作业1 - 网络拓扑创建
  20. Axure数据可视化BI大屏设计组件库

热门文章

  1. NodeJS学习笔记 (15)二进制数据-buffer(ok)
  2. 题目:P3131 [USACO16JAN]Subsequences Summing to Sevens S
  3. 设计模式——中介者模式(附代码示例)
  4. 推荐一款简单易懂的VUE导出Tbale导出excel表格插件[ Table-excel ]
  5. 曾经 All In Crypto 的红杉资本,要分家了?
  6. 【读书】 - 无声告白
  7. 无线充电小车的实物图
  8. Excel 2010 SQL应用027 查询同时满足两个条件的记录
  9. Spark调优工具--Sparklens详解
  10. excel如何预览表格中的图片?