详解Pandas与openpyxl库的超强结合

作者:数据分析与统计学之美 时间:2021-09-05 03:52:15 

前言

用过Pandas和openpyxl库的同学都知道,这两个库是相互互补的。Pandas绝对是Python中处理Excel最快、最好用的库,但是使用 openpyxl 的一些优势是能够轻松地使用样式、条件格式等自定义电子表格。

如果你又想轻松的使用Pandas处理Excel数据,又想为Excel电子表格添加一些样式,应该怎么办呢?

但是您猜怎么着,您不必担心挑选。

事实上,openpyxl 支持将数据从 Pandas DataFrame 转换为工作簿,或者相反,将 openpyxl 工作簿转换为 Pandas DataFrame。

DataFrame转工作簿

我们先创建一个DataFrame:


import pandas as pd

data = {
   "姓名": ["张三", "李四"],
   "性别": ["男", "女"],
   "年龄": [15, 25],
}
df = pd.DataFrame(data)
df

结果如下:

详解Pandas与openpyxl库的超强结合

如果想要给表头设置为红色字体,并居中,应该如何设置呢?


from openpyxl import Workbook
from openpyxl.utils.dataframe import dataframe_to_rows
from openpyxl.styles import Font
from openpyxl.styles import Alignment

wb = Workbook()
ws = wb.active

for row in dataframe_to_rows(df, index=False, header=True):
   ws.append(row)

font = Font(name="微软雅黑",size=10, bold=True,italic=False,color="FF0000")
alignment = Alignment(horizontal="center",vertical="center")

for i in range(1,df.shape[1]+1):
   cell = ws.cell(row=1, column=i)
   print(cell.value)
   cell.font = font
   cell.alignment = alignment

wb.save("pandas.xlsx")

结果如下:

详解Pandas与openpyxl库的超强结合

工作簿转DataFrame

如果有这样一份数据,我们想将其转换为DataFrame,应该怎么做?

详解Pandas与openpyxl库的超强结合

其实这个有点多此一举,我们直接使用pandas读取后,处理完数据,在进行样式设计不就行了吗?为何一开始非要使用openpyxl读取工作簿呢?

哈哈,但是既然openpyxl中提供了这种方法,我们就来看看。


import pandas as pd
from openpyxl import load_workbook

workbook = load_workbook(filename="df_to_openpyxl.xlsx")
sheet = workbook.active

values = sheet.values
df = pd.DataFrame(values)  
df

结果如下:

详解Pandas与openpyxl库的超强结合

来源:https://blog.csdn.net/weixin_41261833/article/details/120169556

标签:Pandas,openpyxl库
0
投稿

猜你喜欢

  • Apple在Safari 4中抛弃品牌视觉设计

    2009-02-26 13:05:00
  • 轻松掌握怎样从Windows命令行启动MySQL

    2009-02-23 17:18:00
  • Python网络爬虫与信息提取(实例讲解)

    2022-10-27 20:53:04
  • 基于python实现cdn日志文件导入mysql进行分析

    2024-01-29 07:37:55
  • 深入理解JavaScript作用域和作用域链

    2024-04-10 13:54:17
  • Django缓存系统实现过程解析

    2021-07-22 23:18:09
  • MySQL如何修改字段的默认值和空值

    2024-01-16 16:57:22
  • PHP后台备份MySQL数据库的源码实例

    2023-09-04 14:55:11
  • 图文详解OpenCV中光流以及视频特征点追踪

    2022-12-30 01:45:08
  • Vue.js开发环境搭建

    2024-05-28 15:55:38
  • SQL Serve数据库到DB2连接服务器的实现过程全解

    2010-08-31 15:06:00
  • Python如何实现远程方法调用

    2022-11-11 20:42:15
  • 在html中引入外部js文件,并调用带参函数的方法

    2024-04-16 09:28:03
  • Web2.0视觉风格进化论 之二

    2007-11-03 20:10:00
  • 如何给Python代码进行加密

    2021-08-24 16:24:30
  • php简单日历函数

    2024-05-09 14:47:05
  • 基于python二叉树的构造和打印例子

    2023-05-16 15:35:45
  • Python定时库APScheduler的原理以及用法示例

    2022-05-09 05:45:43
  • Python中的bytes类型用法及实例分享

    2022-12-19 01:50:42
  • SQL和Oracle对数据库事务处理的差异性

    2009-10-14 09:43:00
  • asp之家 网络编程 m.aspxhome.com