Excel 表格提取

news/2025/11/27 15:40:20/文章来源:https://www.cnblogs.com/luckyletop/p/19278171
# -*- coding: utf-8 -*-
"""
Excel 数据加载模块
负责从 Excel 文件加载测试数据,处理数据转换和验证"""import json
from pathlib import Path
from typing import Dict, Any, List, Optional
from openpyxl import load_workbook, Workbook
from openpyxl.worksheet.worksheet import Worksheetclass ExcelDataLoader:"""Excel 数据加载模块"""def __init__(self, file_path: Path):"""初始化数据加载器"""self.file_path = Path(file_path)if not self.validate_file():raise FileNotFoundError(f"文件 {self.file_path} 不存在")def validate_file(self) -> bool:"""验证文件是否存在"""return self.file_path.exists() and self.file_path.is_file()def load_test_data(self, sheet_name: str) -> List[Dict[str, Any]]:"""加载测试数据"""try:workbook = load_workbook(filename=self.file_path, data_only=True)except Exception as e:raise ValueError(f"无法加载文件 {self.file_path}:{e}")if sheet_name not in workbook.sheetnames:raise ValueError(f"文件 {self.file_path} 中不存在名为 {sheet_name} 的工作表")sheet = workbook[sheet_name]return self._parse_sheet_data(sheet)def _parse_sheet_data(self, sheet: Worksheet) -> List[Dict[str, Any]]:"""解析工作表数据"""data_list = []# 获取标题行(第一行)headers = []for cell in sheet[1]:headers.append(cell.value if cell.value else "")# 遍历数据行 (从第二行开始)for row_idx, row in enumerate(sheet.iter_rows(min_row=2, values_only=True), start=2):row_data = {}for col_idx, (header, value) in enumerate(zip(headers, row)):if header:row_data[header] = value# 转换数据类型row_data = self.convert_data_types(row_data)# 将数据添加到列表中data_list.append(row_data)print(f"加载数据行 {row_idx}:{json.dumps(row_data, ensure_ascii=False)}")return data_listdef convert_data_types(self, data: Dict[str, Any]) -> Dict[str, Any]:"""转换数据类型自动转换数据类型转换规则:- 字符串 "null" → None- JSON 字符串 → Dict/List- 数字字符串 → int/float- 空单元格 → None- 布尔字符串 "true"/"false" → True/False"""converted = {}for key, value in data.items():converted[key] = self._convert_value(value)return converteddef _convert_value(self, value: Any) -> Any:"""转换单个值Args:value: 原始值Returns:转换后的值"""# 空值处理if value is None or value == '':return None# 字符串 "null" 转换为 Noneif isinstance(value, str) and value.lower() == 'null':return None# 布尔字符串转换if isinstance(value, str):if value.lower() == 'true':return Trueelif value.lower() == 'false':return False# JSON 字符串解析if isinstance(value, str) and (value.startswith('{') or value.startswith('[')):try:return json.loads(value)except json.JSONDecodeError:# 不是有效的 JSON,保持原样pass# 数字字符串转换if isinstance(value, str):# 尝试转换为整数try:# 检查是否包含小数点if '.' not in value:return int(value)except ValueError:pass# 尝试转换为浮点数try:return float(value)except ValueError:pass# 保持原值return valuedef write_result(self, sheet_name: str, row_num: int, column_num: int, result: Any):"""写入测试结果"""try:workbook = load_workbook(filename=self.file_path)except Exception as e:raise ValueError(f"无法加载文件 {self.file_path}:{e}")if sheet_name not in workbook.sheetnames:raise ValueError(f"文件 {self.file_path} 中不存在名为 {sheet_name} 的工作表")sheet = workbook[sheet_name]try:sheet.cell(row=row_num, column=column_num).value = resultworkbook.save(self.file_path)print(f"写入结果到文件 {self.file_path} 成功")return Trueexcept Exception as e:raise ValueError(f"无法写入结果到文件 {self.file_path}:{e}")if __name__ == '__main__':loader = ExcelDataLoader(Path(r"C:\Users\dujiale\PycharmProjects\TestApiFramework\data\supdatas.xlsx"))data = loader.load_test_data("supinfor")print(data)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

活动烟花表演公司TOP5权威推荐:专业评测指南,甄选企业助力

随着商业庆典、文旅活动、节日晚会等场景对沉浸式视听体验的需求激增,高品质烟花表演已成为活动吸睛引流、品牌造势的核心载体。2024年行业数据显示,国内专业烟花表演市场规模突破120亿元,年增速达38%,但32%的客户…

详细介绍C++中inline函数的优缺点

inline 函数是 C++ 中用于优化函数调用性能的特性,但其效果并非绝对,需结合场景权衡利弊。以下从优点、缺点及使用边界三方面展开分析: 一、inline 函数的核心优点 1. 减少函数调用开销,提升执行效率 函数调用需经…

2025年下半年工业大风扇/工业大吊扇/厂家综合实力排行榜TOP5推荐

随着工业节能与通风需求的持续增长,2025年下半年工业大风扇市场呈现快速发展态势。本文基于行业调研数据与用户反馈,为您推荐五家综合实力突出的工业大风扇生产企业。榜单排名不分先后,旨在为用户提供参考选择,其中…

模拟赛 R25

T2 - 玩具质检 题目描述 小 Z 现在成为了玩具厂的厂长,为了保证出厂玩具的质量,他决定对这些玩具进行抽样检查。 具体来说,玩具厂生产的这批玩具个数为 \(n\),编号为 \(1,2,\cdots,n\)。小 Z 进行了若干次抽查,其…

2025上海的留学中介哪个机构好

2025上海的留学中介哪个机构好一、2025年上海留学中介如何选择许多上海学生在搜索“2025上海的留学中介哪个机构好”时,核心诉求是找到一家靠谱、透明且本地化服务成熟的机构。作为从业15年的国际教育规划师,我常被家…

2025年河北水利相关咨询公司权威推荐榜单:智能水务系统开发‌/住宅水电安装维护‌/水利监测源头公司精选

在河北省积极推进智慧水利与水资源集约安全利用的背景下,专业的水利相关咨询服务已成为支撑区域水资源管理、水灾害防治与水生态保护的关键力量。据行业数据显示,2024年全国水利管理业投资完成额突破1.2万亿元,其中…

2025 年 11 月红木装修品牌权威推荐榜:复古/古典/别墅/四合院高端整装设计,精选原料与工艺质量深度解析

2025 年 11 月红木装修品牌权威推荐榜:复古/古典/别墅/四合院高端整装设计,精选原料与工艺质量深度解析 红木装修作为中国传统建筑文化的重要载体,近年来在高端住宅、商业空间及文化场所中的应用日益广泛。随着消费…

清障车2025年度实力排行,口碑优良厂家精选推荐,折臂高空作业车/二手蓝牌平板拖车/蓝牌重载清障车/蓝牌清障车/清障车厂家排行榜单

行业洞察与榜单背景 随着我国道路交通网络的不断完善和汽车保有量的持续增长,清障车作为道路救援体系的重要装备,市场需求呈现稳步上升态势。据行业数据显示,2024年国内清障车市场规模已突破百亿元,预计2025年将保…

解决 Win11 启动程序卡顿以及软件打开慢的问题。

在网上查了很多资料,办法如下: 1.发现了卡顿来源,只要禁用下面开关即可解决问题。关闭 安全中心---应用和浏览器控制----智能应用控制设置

2025上海最出名的留学中介机构

2025上海最出名的留学中介机构一、2025年上海留学中介选择指南作为从事国际教育规划工作超过12年的专业顾问,我经常被学生和家长问及:2025年上海地区哪些留学中介机构值得信赖?根据《2025中国留学中介口碑调研白皮书…

2025年北京油气润滑系统制造厂哪家专业、生产厂哪家合作案例

为帮助工业制造企业精准锁定适配生产需求的油气润滑系统合作伙伴,避免因选型不当导致的设备故障、工艺波动及成本浪费,我们从技术适配性(设备-油品-工艺匹配度、参数调试能力)、案例覆盖广度(合作企业规模与行业类…

2025上海留学中介最好的是哪家

2025上海留学中介最好的是哪家一、2025上海留学中介如何选择许多计划在2025年出国深造的学生及家长,常常会提出一个核心问题:上海地区哪家留学中介机构更为可靠?作为一位拥有十年经验的国际教育规划师,笔者认为,选…

2025源头烟雾机厂家TOP5权威推荐:质量好的烟雾机优质供

舞台作为演艺、文旅、娱乐场景的核心视觉支撑,直接影响现场氛围与观众沉浸感。近年来,随着户外演出、大型文旅项目的爆发式增长,市场对防雨耐用、安全稳定、效果精准的烟雾机需求激增。但行业内存在产品同质化严重、…

2025上海留学机构有哪些

2025上海留学机构有哪些一、2025上海留学机构有哪些 随着2025年留学申请季的临近,许多上海学生和家长开始关注本地留学中介的选择。作为从业15年的上海地区留学申请规划导师,我经常被问到“上海有哪些可靠的留学机构…

点阵液晶屏驱动LCD显示驱动芯片-VK0256C 液晶显示驱动原厂【FAE技术支持】

VK0256C是一个点阵式存储映射的LCD驱动器,可支持最大256点(32EGx8COM)的LCD 屏。单片机可通过3/4线串行接口配置显示参数和发送显示数据,也可通过指令进入省电模式。LJQ6942 产品品牌:永嘉微电/VINKA 产品型号:V…

HTTP 状态

HTTP 状态/** Copyright 2002-2021 the original author or authors.** Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the Lic…

MySQL 9.5 正式发行(GA)【转】

MySQL 9.5创新版于2025年10月21日正式发行,让我们一起快速浏览一下该版本有哪些特性。 MySQL 9.5在账号管理、性能优化、安全性、功能扩展等多个核心领域都有重要更新,其核心是提升管理灵活性、运行性能与安全合规性…

2025年聚氨酯发泡保温厂家联系电话汇总 全国重点企业官方联系方式与高效采购指南

本文基于2025年行业公开数据及中国建筑节能协会保温材料行业报告,结合推荐对象参考内容,从企业资质、产品性能、服务网络等维度筛选5个推荐对象,旨在为聚氨酯发泡保温领域提供可靠联系方案。根据行业统计,聚氨酯保…

2025年北京cppm课程机构权威推荐榜单:cppm课程培训‌/cppm证书‌/cppm考试源头机构精选

在采购与供应链管理专业化要求不断提高的背景下,CPPM(注册职业采购经理)认证已成为衡量采购专业人员能力的重要标准。根据行业数据显示,CPPM认证的市场需求量年均增长率稳定在15%以上,2024年全国报考人数同比增长…

深入解析:缓存异常:缓存穿透、缓存击穿、缓存雪崩

深入解析:缓存异常:缓存穿透、缓存击穿、缓存雪崩pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas"…