Python采集学习笔记-读取excel数据

表格格式

方法一:使用xlrd

import xlrd

1.读取Excel文件

workbook = xlrd.open_workbook('plc.xlsx')

2.读取第一个表

sheet = workbook.sheet_by_index(0)

 3.获取表格总行数

total_rows = sheet.nrows

 4.创建列表,存储表格一行中每一列信息

plc_info = []
for row in range(1, total_rows):  # 获取第1到最后行的数据
    id = int(sheet.cell_value(row,0)) #获取第一行索引为0的数据
    plc_name = sheet.cell_value(row, 1)  # 获取PLC名
    plc_ip = sheet.cell_value(row, 2)  # 获取IP地址
    db_number = int(sheet.cell_value(row, 3))  # 获取DB块号
    start_address = int(sheet.cell_value(row,4)) #获取起始地址
    db_size = int(sheet.cell_value(row, 5))  # 获取DB大小
    data_type = sheet.cell_value(row, 6)  # 获取数据类型

5.将每一行的数据插入到列表中

plc_info.append({'id':id,'name': plc_name, 'ip': plc_ip, 'db': db_number,
 'address': start_address,'db_size': db_size, 'data_type': data_type})

6.打印total_rows,plc_info

  源码

import xlrd

# 读取Excel文件
workbook = xlrd.open_workbook('plc.xlsx')
# 读取第一个表
sheet = workbook.sheet_by_index(0)
# 获取表格总行数
total_rows = sheet.nrows
print(total_rows)
# 获取表的PLC信息
plc_list = []
for row in range(1, total_rows):  # 获取第1到最后行的数据
    id = int(sheet.cell_value(row,0)) #获取第一行索引为0的数据
    plc_name = sheet.cell_value(row, 1)  # 获取PLC名
    plc_ip = sheet.cell_value(row, 2)  # 获取IP地址
    db_number = int(sheet.cell_value(row, 3))  # 获取DB块号
    start_address = int(sheet.cell_value(row,4)) #获取起始地址
    db_size = int(sheet.cell_value(row, 5))  # 获取DB大小
    data_type = sheet.cell_value(row, 6)  # 获取数据类型

    plc_list.append({'id':id,'name': plc_name, 'ip': plc_ip, 'db': db_number, 'address': start_address,
                            'db_size': db_size, 'data_type': data_type})
print(plc_list)

 

方法二:使用pandas

import pandas as pd

1.读取excel表数据

data = pd.read_excel('./plc.xlsx', sheet_name='plc')

 2.创建列表,遍历表格数据存储到字典

plc_list = []
for _, row in data.iterrows():
    plc_dict = {
        'id': row['id'],
        'plc_name':row['plc_name'],
        'plc_ip': row['plc_ip'],
        'db_number': row['db_number'],
        'start_address': row['start_address'],
        'db_size':row['db_size'],
        'data_type':row['data_type']
    }

3.将字典数据添加到列表中

plc_list.append(plc_dict)

4.打印plc_list

 源码

import pandas as pd

# 读取excel表数据存储以字典存储到列表
data = pd.read_excel('./plc.xlsx', sheet_name='plc')
plc_list = []
for _, row in data.iterrows():
    plc_dict = {
        'id': row['id'],
        'plc_name':row['plc_name'],
        'plc_ip': row['plc_ip'],
        'db_number': row['db_number'],
        'start_address': row['start_address'],
        'db_size':row['db_size'],
        'data_type':row['data_type']
    }
    plc_list.append(plc_dict)
print(plc_list)

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/358005.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】System V 共享内存

文章目录 一、System V共享内存的原理共享内存的内核数据结构 二、共享内存的使用1. 创建shmget()系统调用创建shm在命令行中查询共享内存 2. 释放使用命令释放共享内存资源使用shmctl释放共享内存资源 3. 关联4. 去关联 三、用共享内存实现server&client通信 一、System V…

【架构】Docker实现集群主从缩容【案例4/4】

实现集群主从缩容【4/4】 接上一节,在当前机器为4主4从的架构上,减缩容量为3主3从架构。即实现删除6387和6388. 示意图如下: 第一步:查看集群情况(第一次) redis-cli --cluster check 127.0.0.1:6387roo…

负载均衡技术助力企业数字化转型和高可用架构实现

文章目录 什么是高可用架构什么是负载均衡负载均衡设备硬件负载均衡的代表产品软件负载均衡的代表产品 负载均衡基于OSI模型分层负载均衡在网络层负载均衡在传输层负载均衡在应用层 优先考虑负载均衡的场景硬件负载均衡的缺点云负载均衡正在成为最佳选择企业数字化转型对负载均…

Spring-boot项目+Rancher6.3部署+Nacos配置中心+Rureka注册中心+Harbor镜像仓库+NFS存储

目录 一、项目概述二、环境三、部署流程3.1 Harbor部署3.1.1 docker安装3.1.2 docker-compose安装3.1.3 安装证书3.1.4 Harbor下载配置安装 3.2 NFS存储搭建3.3 Rancher平台配置3.3.1 NFS存储相关配置3.3.2 Harbor相关配置3.3.3 Nacos部署及相关配置3.3.4 工作负载deployment配…

石油化工设备状态监测与健康管理

在石油化工行业,设备长时间稳定运行至关重要,而PreMaint作为智能监测与健康管理领域的领军者,正在为该行业设备状态的实时监测、健康管理以及智能诊断提供全新的解决方案。 一、状态监测的必要性 石化行业设备的特殊性质要求对其状态进行持续…

如何在 Mac 中运行 Office 办公软件

虽然 Office 软件也有 Mac 版本的,但是有蛮多小伙伴用起来还是感觉不得劲,毕竟接触了太久的 Windows,所以想要使用 Windows 版本的 Office 软件。 今天就给大家介绍一下怎么在 Mac 电脑中运行 Windows 版本的办公软件,在这里就需…

【EEG信号处理】ERP相关

ERP,全称为event-related potential,中文是事件相关电位。 首先要明确的一点是,ERP是根据脑电图EEG得到的,他是EEG的一部分,是最常用的时域分析方法 可能有一部分是介绍不到的,望谅解 在维基百科中给的定义…

手机屏幕生产厂污废水处理需要哪些工艺设备

随着手机行业的快速发展,手机屏幕生产厂的规模也越来越大,但同时也带来了大量的污废水排放问题。为了保护环境和人类的健康,手机屏幕生产厂需要采取适当的工艺设备来处理污废水。本文将介绍手机屏幕生产厂污废水处理所需的工艺设备。 首先&am…

Spring:JDBCTemplate 的源码分析

一:JdbcTemplate的简介 JdbcTemplate 是 Spring Template设置模式中的一员。类似的还有 TransactionTemplate、 MongoTemplate 等。通过 JdbcTemplate 我们可以使得 Spring 访问数据库的过程简单化。 二:执行SQL语句的方法 1:在JdbcTempla…

提升编程效率的利器: 解析Google Guava库之集合篇RangeSet范围集合(五)

在编程中,我们经常需要处理各种范围集合,例如时间范围、数字范围等。传统的集合类库往往只能处理离散的元素集合,对于范围集合的处理则显得力不从心。为了解决这个问题,Google的Guava库提供了一种强大的数据结构——RangeSet&…

一文掌握 Golang 加密:crypto/cipher 标准库全面指南

一文掌握 Golang 加密:crypto/cipher 标准库全面指南 引言Golang 和加密简介crypto/cipher 库概览使用 crypto/cipher 实现加密高级功能和技巧最佳实践和性能优化总结资源推荐 引言 在现代软件开发领域,安全性是一个不容忽视的重要议题。随着信息技术的…

黑盒测试用例的具体设计方法(7种)

7种常见的黑盒测设用例设计方法,分别是等价类、边界值、错误猜测法、场景设计法、因果图、判定表、正交排列。 (一)等价类 1.概念 依据需求将输入(特殊情况下会考虑输出)划分为若干个等价类,从等价类中选…

备战蓝桥杯---数据结构与STL应用(基础实战篇1)

话不多说,直接上题: 当然我们可以用队列,但是其插入复杂度为N,总的复杂度为n^2,肯定会超时,于是我们可以用链表来写,同时把其存在数组中,这样节点的访问复杂度也为o(1).下面是AC代码: 下面我们来…

Vim实战:使用Vim实现图像分类任务(一)

文章目录 摘要安装包安装timm 数据增强Cutout和MixupEMA项目结构编译安装Vim环境环境安装过程安装库文件 计算mean和std生成数据集 摘要 论文:https://arxiv.org/pdf/2401.09417v1.pdf 翻译: 近年来,随着深度学习的发展,视觉模型…

项目解决方案:高清视频监控联网设计方案

目 录 一、客户需求 二、网络拓扑图 三、方案描述 四、服务器配置 五、方案优势 1. 多级控制 2. 平台可堆叠使用 3. 支持主流接入协议 4. 多种终端显示 5. 视频质量诊断 6. 客户端功能强大 7. 一机一档 一、客户需求 客户现场存在两个网络环境&#xff0c…

25考研北大软微该怎么做?

25考研想准备北大软微,那肯定要认真准备了 考软微需要多少实力 现在的软微已经不是以前的软微了,基本上所有考计算机的同学都知道,已经没有什么信息优势了,只有实打实的有实力的选手才建议报考。 因为软微的专业课也是11408&am…

HarmonyOS4.0系统性深入开发31创建列表(List)

创建列表(List) 概述 列表是一种复杂的容器,当列表项达到一定数量,内容超过屏幕大小时,可以自动提供滚动功能。它适合用于呈现同类数据类型或数据类型集,例如图片和文本。在列表中显示数据集合是许多应用…

[DotNetGuide]C#/.NET/.NET Core优秀项目和框架精选

前言 注意:排名不分先后,都是十分优秀的开源项目和框架,每周定期更新分享(欢迎关注公众号:追逐时光者,第一时间获取每周精选分享资讯🔔)。 帮助开发者发现功能强大、性能优越、创新前…

R语言学习case7:ggplot基础画图(核密度图)

step1: 导入ggplot2库文件 library(ggplot2)step2&#xff1a;带入自带的iris数据集 iris <- datasets::irisstep3&#xff1a;查看数据信息 dim(iris)维度为 [150,5] head(iris)查看数据前6行的信息 step4&#xff1a;画图展示 plot2 <- ggplot(iris,aes(Sepal.W…

基于C#制作一个连连看小游戏

基于C#制作一个连连看小游戏,实现:难易度选择、关卡选择、倒计时进度条、得分计算、音效播放等功能。 目录 引言游戏规则开发环境准备游戏界面设计游戏逻辑实现图片加载与显示鼠标事件处理游戏优化与扩展添加关卡与难度选择说明</