当前位置: 首页 > news >正文

Excel 表格提取

# -*- 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.zskr.cn/news/62828.html

相关文章:

  • 活动烟花表演公司TOP5权威推荐:专业评测指南,甄选企业助力
  • 模拟赛 R25
  • 解决 Win11 启动程序卡顿以及软件打开慢的问题。
  • 2025年北京油气润滑系统制造厂哪家专业、生产厂哪家合作案例
  • 2025上海留学中介最好的是哪家
  • HTTP 状态
  • 点阵液晶屏驱动LCD显示驱动芯片-VK0256C 液晶显示驱动原厂【FAE技术支持】
  • MySQL 9.5 正式发行(GA)【转】
  • 深入解析:缓存异常:缓存穿透、缓存击穿、缓存雪崩
  • 家长必看!2025-2026申请季A-Level全日制机构排名(6 家头部详解+三大梯队)
  • 南昌滑雪场推荐!七星岭国际滑雪场:解锁冬日限定速度与激情
  • 2025 年 11 月铁盒厂家推荐排行榜,食品铁盒/保健品铁盒/化妆品铁盒/茶叶铁盒/磁吸铁盒/异形铁盒,精选耐用设计与定制工艺之选
  • 详细介绍:【Linux权限 (二)】Linux权限机制深度解析:umask如何决定默认权限与粘滞位的妙用
  • 2025 年 11 月留香阁食品推荐排行榜,预制菜/调理半成品/咀留香/黑椒牛排,精选优质食材与创新工艺,满足便捷餐饮与家庭烹饪的多重需求!
  • quic协议监听与Alt-Svc响应头的应用
  • 全球前四!京东云云海AI存储跻身IO500高性能存储榜单
  • 体育竞技赛事赋能 全项目亚运奥运提升
  • 2025 年 11 月电动伸缩门厂家权威推荐榜:悬浮门/空降闸/工业伸缩门,智能防护与耐用品质全景解析
  • 2025财务档案托管寄存档案服务公司TOP5推荐:专业机构
  • 借助 GitHub Workflow 定时获取博客状态
  • 零九CDN — 国内网站加速 + DD/CC 攻击防御解决方案
  • 体育赛事多元竞技价值 球类奥运亚运实战提升
  • 2025 年美发会员管理软件最新推荐榜,技术实力与市场口碑深度解析的优质品牌合集理发店会员系统推荐
  • 2025年口碑好的湖北塑料桶实力厂家排行榜
  • 2025年口碑好、服务佳、资质全的食品包装设计专业公司推荐
  • 西城区离婚律师事务所推荐:专注婚姻家事法律服务机构盘点
  • 2025上海留学中介哪家靠谱
  • 2025 最新推荐!学术论文AI写作工具排行榜:核心优势与使用场景评测
  • 华为设备接入视频汇聚平台EasyCVR不上线问题排查实录
  • 治疗妇科炎症的药有哪些?科学认识与合理应对指南