第十一天-Excel的操作

目录

1.xlrd-Excel的读模块

安装

使用

获取工作簿

读取工作簿的内容

xlsxwriter-Excel的写模块

安装

使用

生成图表

add_series参数

图表的样式

demo:生成图表

Excel的操作在python中有多个模块,为了能够快速使用,选择了相对简单且功能全面的模块来介绍。

1.xlrd-Excel的读模块

安装

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple xlrd==1.2.0

导入: import xlrd

使用

book=xlrd.open_workbook(excel文件)

获取工作簿

读取工作簿的内容

复制代码
import xlrd

book=xlrd.open_workbook("小小小向日葵.xlsx")

sheet0=book.sheet_by_index(0)

print("总行数:",sheet0.nrows)
print("总列数:",sheet0.ncols)

for s in sheet0.get_rows():
    #print(s)
    values=[]
    for i in s:
        values.append(i.value)
    print(values)

xlsxwriter-Excel的写模块

安装

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple xlsxwriter

导入 import xlsxwriter

使用

#生成excel对象

book=xlswriter.Workbook("Excel文件名")

#创建工作簿

sheet=book.add_sheet(工作簿)

demo:复制Excel

复制代码
# coding:utf-8

import xlrd
import xlsxwriter


def copy_excel(path,newfile):
    #读取Excel
    book=xlrd.open_workbook(path)
    sheets=book.sheets()
    newbook = xlsxwriter.Workbook(newfile)
    for sheet in sheets:
        sheetname=sheet.name
        #根据名称读取工作簿
        sheet = book.sheet_by_name(sheetname)
        #创建新的工作簿
        newsheet=newbook.add_worksheet(sheetname)
        #读取工作簿数据
        for index,row in enumerate(sheet.get_rows()):
            print("index:{},rows:{}".format(index,row))
            for sub_index,sub_row in enumerate(row):
                newsheet.write(index,sub_index,sub_row.value)
    newbook.close()

if __name__ == '__main__':
    copy_excel("医生信息.xlsx",newfile="医生信息1.xlsx")

生成图表

add_series参数

图表的样式

demo:生成图表

复制代码
# coding:utf-8

import xlsxwriter

if __name__ == '__main__':
    book=xlsxwriter.Workbook("图表Excel.xlsx")
    sheet=book.add_worksheet("图表")

    data=[
        ["优秀","良好","中","差"],
        [100, 200, 5, 10]
    ]
    sheet.write_column("A1", data[0])
    sheet.write_column("B1", data[1])
    #创建图表:饼图
    chart=book.add_chart({"type":"pie"})
    chart.add_series({
        "categories":"=图表!$A$1:$A$4",
        "values":"=图表!$B$1:$B$4",
        "name":"学生成绩占比"
    })
    chart.set_title({"name":"学生成绩占比"})
    sheet.insert_chart("A10",chart)
    book.close()
相关推荐
涛声依旧-底层原理研究所几秒前
Node.js在高并发低延迟场景中的优势
java·人工智能·python·node.js
凯丨11 分钟前
200 行 Python 训练一个 GPT:Karpathy 的极简主义 AI 教育实验
人工智能·python·gpt
Mr. zhihao11 分钟前
BM25 混合检索详解:为什么向量检索不够,还要加一个关键词检索
python·rag·bm25
悟乙己12 分钟前
python DoWhy 库使用案例: SaaS 公司的客服案例
开发语言·python
2501_9272835813 分钟前
堆垛机立体库:告别人工翻找与货物堆压
大数据·人工智能·低代码·自动化·区块链
console.log('npc')22 分钟前
Windows试用期重置工具,纯官方 / 安全教程
运维·自动化·typora·脚本
专注VB编程开发20年32 分钟前
我制作excel工作簿的选项卡,发给deep seek, 昨天修改了一天
前端·vue.js·excel
在学了加油36 分钟前
Inception v1学习笔记
笔记·python·学习
Cthy_hy41 分钟前
Python算法竞赛:集合去重+字典映射 核心用法一站式整理
数据结构·python·算法
索西引擎42 分钟前
【langchain 1.0】ChromaDB 原生 API 实战:为 LangChain 向量库打造管理工具集
python·ai·langchain