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

表格格式

方法一:使用xlrd

python 复制代码
import xlrd

1.读取Excel文件

python 复制代码
workbook = xlrd.open_workbook('plc.xlsx')

2.读取第一个表

python 复制代码
sheet = workbook.sheet_by_index(0)

3.获取表格总行数

python 复制代码
total_rows = sheet.nrows

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

python 复制代码
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.将每一行的数据插入到列表中

python 复制代码
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

源码

python 复制代码
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

python 复制代码
import pandas as pd

1.读取excel表数据

python 复制代码
data = pd.read_excel('./plc.xlsx', sheet_name='plc')

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

python 复制代码
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.将字典数据添加到列表中

python 复制代码
plc_list.append(plc_dict)

4.打印plc_list

源码

python 复制代码
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)
相关推荐
十安_数学好题速析4 分钟前
不等证明:从柯西不等式到裂项相消
笔记·学习·高考
源码之家11 分钟前
基于python新闻数据分析可视化系统 Hadoop 新闻平台 爬虫 情感分析 舆情分析 可视化 Django框架 vue框架 机器学习 大数据毕业设计✅
大数据·爬虫·python·数据分析·毕业设计·情感分析·新闻
IT油腻大叔14 分钟前
DeepSeek-多层注意力计算机制理解
python·深度学习·机器学习
wdfk_prog15 分钟前
[Linux]学习笔记系列 -- [kernel]signal
linux·笔记·学习
小呀小萝卜儿17 分钟前
2025-11-17 学习记录--Python-机器学习作业:项目1 - PM2.5预测
python·学习·机器学习
闲人编程23 分钟前
CPython与PyPy性能对比:不同解释器的优劣分析
python·算法·编译器·jit·cpython·codecapsule
kk哥889939 分钟前
PyCharm 2025.1 是什么编程语言,如何安装
python·php
海拥40 分钟前
基于 IPIDEA 的 SERP 结构化数据抽取与趋势监控的工程化实践
python
yivifu1 小时前
EPUB文件HTML批量修改避坑
python·epub·zipfile
B站_计算机毕业设计之家1 小时前
python手写数字识别系统 CNN算法 卷积神经网络 OpenCV和Keras模型 计算机视觉 (建议收藏)✅
python·深度学习·opencv·机器学习·计算机视觉·cnn