【使用xlrd、xlutils读写excel】

使用xlrd、xlutils读写excel

    • 1、环境和版本
    • 2、相关使用方法封装
      • 2.1 根据行下标返回对应行数据
      • 2.2 根据列下标返回对应列数据
      • 2.3 读取指定单元格数据
      • 2.4 通过表单名读取全部数据
      • 2.5 通过表索引读取全部数据
      • 2.6 向已存在sheet中追加数据
      • 2.7 原文件基础上新建的sheet并写入数据
    • 3、其他踩坑

1、环境和版本

  • 电脑:win
  • excel文件格式.xls
  • xlrd 版本 1.2.0(高版本存在部分属性不兼容),安装指定版本pip install xlrd == 1.2.0
  • xlutils 版本:2.0.0

2、相关使用方法封装

2.1 根据行下标返回对应行数据

def read_excel_by_row(file_path, sheet_index, row_index):
    """读取指定行数据"""
    data = xlrd.open_workbook(file_path)
    sheet = data.sheet_by_index(sheet_index)
    nrows = sheet.nrows  # 行数
    ncols = sheet.ncols  # 列数
    try:
        table_list = sheet.row_values(rowx=row_index, start_colx=0, end_colx=None)  # start_colx:开始列,end_colx:结束列
        return table_list
    except Exception as e:
        print("当前表单行数%s行%s列" % (nrows, ncols), e)

2.2 根据列下标返回对应列数据

def read_excel_by_col(file_path, sheet_index, col_index):
    """读取指定列数据"""
    data = xlrd.open_workbook(file_path)
    sheet = data.sheet_by_index(sheet_index)
    nrows = sheet.nrows  # 行数
    ncols = sheet.ncols  # 列数
    try:
        table_list = sheet.col_values(colx=col_index, start_rowx=0, end_rowx=None)  # start_rowx:开始行,end_colx:结束行
        return table_list
    except Exception as e:
        print("当前表单行数%s行%s列" % (nrows, ncols), e)

2.3 读取指定单元格数据

def read_excel_by_cell(file_path, sheet_index,row_index,col_index):
    """
    读取指定单元格数据
    :param file_path: 文件路径. .xls格式的文件
    :param sheet_index: sheet表索引
    :param row_index: 行下标
    :param col_index: 列下标
    :return: 第row_index行col_index数据
    """
    wb = xlrd.open_workbook(file_path)
    sheet = wb.sheet_by_index(sheet_index)
    value = sheet.cell_value(row_index, col_index)
    # value_type = sheet.cell_type(row_index, col_index) # 单元格类型  0->empty,1->string,2->number,3->date,4->boolean,5->error
    return value

2.4 通过表单名读取全部数据

def red_excel_by_sheet_name(file_path, sheet_name):
    """
    读取excel数据并返回
    :param file_path: 文件路径 .xls文件
    :param sheet_index: sheet表单所以
    :return: 表单List
    """
    data = xlrd.open_workbook(file_path)
    # table = data.sheet_by_index(sheet_index)
    table = data.sheet_by_name(sheet_name)
    # 表格行数
    nrows = table.nrows #行数
    ncols = table.ncols
    # print(nrows, ncols)
    table_list = []
    for row_index in range(0, nrows):
        temp_list = table.row_values(rowx=row_index, start_colx=0, end_colx=None)  # start_colx:开始列,end_colx:结束列
        table_list.append(temp_list)
    return table_list

2.5 通过表索引读取全部数据

def red_excel_by_sheet_index(file_path, sheet_index):
    """
    通过表单索引读取excel数据并返回
    :param file_path: 文件路径
    :param sheet_index: 表单索引
    :return:对应表单的数据
    """
    data = xlrd.open_workbook(file_path)
    table = data.sheet_by_index(sheet_index)
    # table = data.sheet_by_name(sheet_index)
    # 表格行数
    nrows = table.nrows
    ncols = table.ncols
    # print(nrows, ncols)
    table_list = []
    for row_index in range(0, nrows):
        temp_list = table.row_values(rowx=row_index, start_colx=0, end_colx=None)  # start_colx:开始列,end_colx:结束列
        table_list.append(temp_list)
    return table_list

2.6 向已存在sheet中追加数据

def append_to_sheet(file_path, sheet_tag, data):
    """向已存在的表中追加数据
    :param file_path: 文件路径(sheet已经存在的情况)
    :param sheet_tag: sheet表标识 sheet_name or sheet_index
    :param data: 要追加的数据
    :return: None
    """
    try:
        # 打开文件
        openFile = xlrd.open_workbook(file_path)
        # 读取文件,准备写入信息
        if isinstance(sheet_tag, int): #如果参数是int根据索引查找表单
            max_row = openFile.sheet_by_index(sheet_tag).nrows
        else: #如果参数是str根据名称查找表单
            max_row = openFile.sheet_by_name(sheet_tag).nrows
        print("当前最大行=", max_row)
        write = copy(openFile)
        write_sheet = write.get_sheet(sheet_tag)
        start_row = max_row  # 从表格的第5行开始写入数据
        # 一行一行的写,一行对应的所有列
        for d in data:  # 控制行
            col = 0
            for value in d:  # 控制每一列
                write_sheet.write(start_row, col, value)  # rou代表列,col代表行,value写入值
                col += 1
            start_row += 1
        # 保存
        write.save(file_path)
    except FileNotFoundError:
        print(f"文件 {file_path} 未找到。")
    except xlrd.XLRDError:
        print("无法读取Excel文件,请检查文件格式或内容。")
    except Exception as e:
        print(f"发生未知错误:{e}")

2.7 原文件基础上新建的sheet并写入数据

def append_date_to_new_sheet(file_path, sheet_name,data):
    """
    原文件基础上新建的sheet并写入数据
    :param file_path:
    :param sheet_name:
    :param data:list数据,例:data = [[1,2],[3,4]]
    :return:None
    """
    openFile = xlrd.open_workbook(file_path)
    write = copy(openFile)
    write.add_sheet(sheet_name)
    write_sheet = write.get_sheet(sheet_name) # 已存在的表单,实际需要新建
    row = 0  # 从表格的第二行开始写入数据
    # 一行一行的写,一行对应的所有列
    for d in data:  # 控制行
        col = 0
        for one in d:  # 控制每一列
            write_sheet.write(row, col, one)  # rou代表列,col代表行,one写入值
            col += 1
        row += 1
    write.save(file_path)

3、其他踩坑

xlrd 仅1.2.0 版本支持.xls 文件,更高版本不支持,没有删除sheet功能
openpyxl 支持.xlsx 读取的时候一直显示文件被损坏, 不支持.xls格式,有remove功能,但是使用过程中也有问题,后续研究明白再做补充吧

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

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

相关文章

漫谈微服务网关

一、什么是服务网关 服务网关 路由转发 过滤器 1、路由转发:接收一切外界请求,转发到后端的微服务上去; 2、过滤器:在服务网关中可以完成一系列的横切功能,例如权限校验、限流以及监控等,这些都可以通过…

性能优化(CPU优化技术)-NEON指令详解

原文来自ARM SIMD 指令集:NEON 简介 🎬个人简介:一个全栈工程师的升级之路! 📋个人专栏:高性能(HPC)开发基础教程 🎀CSDN主页 发狂的小花 🌄人生秘诀&#xf…

服务器版本命令查看

1、# uname -a (Linux查看版本当前操作系统内核信息) 2、# cat /proc/version (Linux查看当前操作系统版本信息) 3、# cat /etc/issue 或 cat /etc/redhat-release (Linux查看版本当前操作系统发行版信息&…

前端项目,个人笔记(五)【图片懒加载 + 路由配置 + 面包屑 + 路由行为修改】

目录 1、图片懒加载 步骤一:自定义全局指令 步骤二:代码中使用 ​编辑步骤三:效果查看 步骤四:代码优化 2、封装组件案例-传对象 3、路由配置——tab标签 4、根据tab标签添加面包屑 4.1、实现 4.2、bug:需要…

k8s详细教程

Kubernetes详细教程 1. Kubernetes介绍 1.1 应用部署方式演变 在部署应用程序的方式上,主要经历了三个时代: 传统部署:互联网早期,会直接将应用程序部署在物理机上 优点:简单,不需要其它技术的参与 缺点…

QT 驾校系统界面布局编写

MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) {ui->setupUi(this);this->resize(ui->label_img->width(),ui->label_img->height());//图片自适应窗口大小ui->label_img->setScaledContents(true);//图片置…

ES集群和分片以及脑裂

文章目录 概要一、概念二、节点角色三、master节点脑裂四、参考 概要 在工作中不可避免会用到ES,而用到ES就不得使用其集群模式了。 单节点的话不得不面临两个重大缺陷:单点故障(高可用)和海量数据存储搜索。 ES通过集群模式解决…

竞争优势:大型语言模型 (LLM) 如何重新定义业务策略

人工智能在内容创作中的突破 在当今快节奏的商业环境中,像 GPT-4 这样的大型语言模型 (LLM) 不再只是一种技术新颖性; 它们已成为重新定义跨行业业务战略的基石。 从增强客户服务到推动创新,法学硕士提供了企业不容忽视的竞争优势。 1. 加强…

LVGL:拓展部件——键盘 lv_keyboard

一、概述 此控件特点: 特殊Button矩阵:lv_keyboard 本质上是一个经过定制的按钮矩阵控件。每个按钮都可以独立触发事件或响应。预定义的键映射:lv_keyboard 自带了一套预设的按键布局和对应的字符映射表,开发者可以根据需要选择…

Spring MVC入门(4)

请求 获取Cookie/Session 获取Cookie 传统方式: RequestMapping("/m11")public String method11(HttpServletRequest request, HttpServletResponse response) {//获取所有Cookie信息Cookie[] cookies request.getCookies();//打印Cookie信息StringBuilder build…

WPF —— 控件模版和数据模版

1:控件模版简介: 自定义控件模版:自己添加的样式、标签,控件模版也是属于资源的一种, 每一个控件模版都有一唯一的 key,在控件上通过template属性进行绑定 什么场景下使用自定义控件模版,当项目里面多个地方…

K8s的Pod出现Init:ImagePullBackOff问题的解决,(以calico网络插件为例)

问题描述: 对于这类问题的解决思路应该都差不多,本文以calico插件安装为例,发现有个Pod的镜像没有pull成功 第一步:查看这个pod的描述信息 kubectl describe pod calico-node-t9rql -n kube-system从上图发现是docker拉取"…

基于Lealfet.js展示Turf.js生成的平滑曲线实践

目录 前言 一、问题的由来 1、创建网页框架 2、创建map对象 3、构建点位,生成路线 二、Turf.js平滑曲线改造 1、官网方法介绍 2、0.4弯曲度曲线 3、0.85弯曲度曲线 4、0.1度弯曲曲线 5、综合对比 总结 前言 在很多的关于路线的gis应用中,我们…

详细教---用Django封装写好的模型

本次我们要用自己写好的热销词条爬虫代码来演示如何用Django把我们写好的模型封装。 第一步:代码准备 热搜词条搜集代码: import requests from lxml import etreeurl "https://tophub.today/n/KqndgxeLl9" headers{User-Agent: Mozilla/5.…

如何本地部署1Panel面板

文章目录 前言1. Linux 安装1Panel2. 安装cpolar内网穿透3. 配置1Panel公网访问地址4. 公网远程访问1Panel管理界面5. 固定1Panel公网地址 前言 1Panel 是一个现代化、开源的 Linux 服务器运维管理面板。高效管理,通过 Web 端轻松管理 Linux 服务器,包括主机监控、…

NLP---Bert分词

目录&#xff1a; Q&#xff1a;bert分词步骤1&#xff1a;构建N * N 的相关性矩阵&#xff0c;计算相邻两个字的相关性&#xff0c;低的话&#xff08;<阈值&#xff09;就切割。2&#xff1a;将A词进行mask计算出A的embedding&#xff0c;然后将AB两个词一起mask&#xff…

除了大众点评,中国未来还会产生多少家这样的人工智能公司? - 学习Yelp公司的软件工程-评价和推荐系统

原文作者&#xff1a;Jason Sleight&#xff0c;ML&#xff08;Machine Learning&#xff09;平台集团技术负责人 翻译&#xff1a;数字化营销工兵 了解数据是Yelp成功的重要组成部分。为了将我们的消费者与当地优秀的企业联系起来&#xff0c;我们每天为各种任务提供数百万条建…

【0274】从shared init file或local init file加载relation cache(2 - 1)

上一篇&#xff1a; 【0273】深入分析 relcache&#xff08;relation descriptor cache&#xff09;初始化第一阶段&#xff08;1&#xff09; 【0264】深入分析relcache&#xff08;relation descriptor cache&#xff09;缓存初始化第2阶段&#xff08;2&#xff09; 1. 前…

JSONP 实现跨域请求案例

后端使用 express 搭建&#xff0c;案例代码如下&#xff1a; const express require(express)const app express() const PORT 3000app.get(/data, (req, res) > {const jsonData {name: Alan,age: 666,city: GD}const callback req.query.callback // 获取前端中的回…

Python分析无人驾驶汽车在桂林市文旅行业推广的问卷

【项目背景】 通过市场调研、文本分析、访谈和问卷调查等方法&#xff0c;探讨&#xff1a; 网民对无人驾驶汽车出行服务的态度。无人驾驶安全员的行业背景。不同人群在旅游时的交通选择偏好。游客及当地居民对桂林市文旅路线的交通满意度。乘客对无人驾驶汽车的满意度。桂林…
最新文章