pandas 修改 Excel 样式

1、简介

使用pandas修改excel的样式,本质上整合了XlsxWriter模块,实现的excel样式修改,下面是XlsxWriter模块功能

  • 100%兼容Excel的xlsx文件;
  • 完整的格式;
  • 合并单元格;
  • 定义名称;
  • 图表;
  • 自动过滤器;
  • 数据验证和下拉列表;
  • 条件格式;
  • 工作簿的PNG、JPEG、BMP、WMF、EMF等图像;
  • 丰富的多格式字符串;
  • 单元格注释;
  • 文本框;
  • 与Pandas模块整合;
  • 用于写入大文件的内存优化模式;

详情:XlsxWriter

2、使用

  • 样式

header_format  = workbook.add_format({

        'bold': True,                          # 字体加粗
        'text_wrap': True,                 # 是否自动换行
        'valign': 'bottom',                  # 垂直对齐方式
        'align': 'center',                     # 水平对齐方式
        'fg_color': '#D7E4BC',          # 单元格背景颜色
        'border': 1,                            # 边框
        'top':2,                                  # 上边框 
        'left':2,                                  # 左边框
        'right':2,                                # 右边框
        'bottom':2,                            # 底边框
        'num_format': 'yyyy-mm-dd',# 格式

})   

或者

        header_format .set_font_size(10)
        header_format .set_bold()
        header_format .set_bg_color('#101010')
        header_format .set_font_color('#FEFEFE')
        header_format .set_align('center')
        header_format .set_align('vcenter')
        header_format .set_bottom(2)
        header_format .set_top(2)
        header_format .set_left(2)
        header_format .set_right(2)

  • 方法 
workbook.add_format({})                                            # 为表格添加样式,参数为一个字典,字典内容{'bold': True, 'align': 'center' }

worksheet.set_column("A:A", 15, header_format)                     # 设置A列的宽度为15,使用header_format样式(header_format样式    <====>    header_format = workbook.add_format({}) ),当然你也可以设置A列到D列"A:D"

worksheet.set_default_row(90)                                      # 默认设置所有行高的高度

worksheet.set_row(0,15,header_format)                              # 设置指定行

worksheet.merge_range('B4:D4', 'Merged Range', merge_format)       # 合并单元格方法,合并B列到D列的第四行

# 或者

worksheet.merge_range('B4:D5', 'Merged Range', merge_format)       # 合并B列到D列的第四行到五行
  • 图表

详情插入图表

3、实际场景使用

假设现在我们需要将一个DataFrame的数据格式的数据保存为我们想要的excel表格,并对生成的excel进行处理

	# list转dataframe
	df = pd.DataFrame(data, columns=['sn', 'Uplink','Downlink','file'])

	writer = pd.ExcelWriter("log_{0}.xlsx".format(time.strftime("%Y%m%d%H%M%S")), engine='xlsxwriter')
	# 保存到本地excel
	df.to_excel(writer, sheet_name='Sheet1', index=False)

	workbook  = writer.book
	worksheet = writer.sheets['Sheet1']

	header_format = workbook.add_format({
	    'valign': 'vcenter',  # 垂直对齐方式
	    'align': 'center', # 水平对齐方式
	})

	header_format1 = workbook.add_format({
	    'valign': 'vcenter', # 垂直对齐方式
	    'align': 'center', # 水平对齐方式
	    'text_wrap': True
	}) 

	worksheet.set_column("A:A", 15, header_format)
	worksheet.set_column("B:C", 60,header_format1)
	worksheet.set_column("D:D", 45,header_format)

	worksheet.set_default_row(90)# 设置所有行高
	worksheet.set_row(0,15,header_format)#设置指定行
	writer.save()
	writer.close()

 

### Spring Boot 整合 MyBatis不到数据库的原因分析 在 Spring Boot 中整合 MyBatis 并配置数据库连接时,如果遇到无法到数据库的情况,可能是由于以下几个原因引起的: #### 1. **数据源配置错误** 如果 `application.properties` 或 `application.yml` 文件中的数据源配置项填写错误,则可能导致程序无法正确连接到目标数据库。常见的错误包括但不限于: - 数据库 URL 错误(例如拼写错误或端口号不对)[^2]。 - 用户名或密码错误。 正确的数据源配置应类似于以下形式: ```properties spring.datasource.url=jdbc:mysql://localhost:3306/your_database_name?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` #### 2. **依赖版本冲突** 如果项目中引入的 MyBatisSpring Boot 的版本不兼容,可能会导致初始化失败或者无法正常加载数据库资源。建议检查项目的 `pom.xml` 文件,确保使用的依赖版本匹配。例如: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.3.0</version> </dependency> ``` #### 3. **未启用 Mapper 接口扫描** 如果没有正确配置 `@MapperScan` 注解来指定 Mapper 接口所在的包路径,MyBatis 将无法识别这些接口,从而引发异常。可以通过以下方式解决此问题[^3]: ```java @SpringBootApplication @MapperScan("com.example.mapper") // 替换为实际的 mapper 路径 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` #### 4. **数据库服务不可用** 当本地开发环境下的 MySQL 或其他数据库服务未启动时,也会报出类似的 “不到数据库” 错误。可以尝试通过命令行或其他工具手动测试数据库连通性,确认其状态是否正常运行。 #### 5. **IDEA 缺乏 SQL 提示支持** 若开发者希望获得更友好的编码体验,在 IDEA 上完成相应设置后能够享受智能补全功能带来的便利。具体做法可参照文档说明调整插件选项以便增强用户体验效果[^4]。 --- ### 解决方案总结 针对上述可能存在的各类状况逐一排查即可定位根本所在;同时注意保持各组件间良好的协作关系以减少不必要的麻烦发生几率。 ```java // 示例代码片段展示如何定义一个简单的 DAO 层类 public interface UserMapper extends BaseMapper<UserEntity> {} ```
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拼命_小李

给点鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值