mysql数据库中多张表导出成excel方式

embedded/2025/3/18 21:11:11/

需求:
用于将mysql数据库中的几百张表导出成excel方式
表中有些字段的值是含有双引号和逗号值,比如json值
表中有些字段是汉字内容
导出的excel要求有表的列名
shell对于含有逗号和双引号的值会错乱分割
数据库中某些字段值是化学符号

import pymysql,os,csv,shutil
target_dir=r'C:\Users\XXX\Desktop\excel'
if  os.path.exists(target_dir):shutil.rmtree(target_dir)os.mkdir(target_dir)
else:os.mkdir(target_dir)myconn=pymysql.connect(host='localhost',port=3306,user='root',password='123456',database='rhtx')
table_sql="select table_name from information_schema.tables where table_schema='rhtx'"
with myconn.cursor() as cursor:cursor.execute(table_sql)table_name=list(cursor.fetchall())for name in table_name:file_name=name[0]+".csv"file_path = os.path.join(target_dir, file_name)sql='select * from '+'rhtx.'+name[0]with myconn.cursor() as cursor:cursor.execute(sql)rows=cursor.fetchall()with open(file_path, mode='w', newline='',encoding='gbk') as file:writer=csv.writer(file)writer.writerow([i[0] for i in cursor.description])writer.writerows(rows)
myconn.close()

http://www.ppmy.cn/embedded/173678.html

相关文章

浅谈AI落地之-加速训练

前言 曾在游戏世界挥洒创意,也曾在前端和后端的浪潮间穿梭,如今,而立的我仰望AI的璀璨星空,心潮澎湃,步履不停!愿你我皆乘风破浪,逐梦星辰! 混合精度: FL32是目前模型存…

低空经济安全保障体系构建方案

一、源头安全设计与认证 飞行器安全冗余设计 动力系统双备份:电动垂直起降(eVTOL)飞行器配备双电机、多电池组,单组故障仍可安全返航。轻量化结构材料:采用碳纤维复合材料+蜂窝夹层设计,抗坠毁强度提升30%。适航认证分级:参照民航标准,对载人/载货飞行器实施分级认证(…

Rust + WebAssembly 开发环境搭建指南

一、安装 Rust 工具链 要开始 Rust WebAssembly 开发,你需要安装标准 Rust 工具链,包括 rustup、rustc 和 cargo。 1. 安装 Rust 工具链 Rust 官方提供 rustup 工具来管理 Rust 版本。你可以使用以下命令安装 Rust: curl --proto https -…

游戏引擎学习第163天

我们可以在资源处理器中使用库 因为我们的资源处理器并不是游戏的一部分,所以它可以使用库。我说过我不介意让它使用库,而我提到这个的原因是,今天我们确实有一个选择——可以使用库。 生成字体位图的两种方式:求助于 Windows 或…

本周安全速报(2025.3.11~3.17)

合规速递 01 瑞士出台新规:关基设施遭遇网络攻击需在24小时内上报 原文: https://www.bleepingcomputer.com/news/security/swiss-critical-sector-faces-new-24-hour-cyberattack-reporting-rule/ 新规要求,关键基础设施组织发现网络攻击后&…

【MySQL】多表查询(笛卡尔积现象,联合查询、内连接、左外连接、右外连接、子查询)-通过练习快速掌握法

在DQL的基础查询中,我们已经学过了多表查询的一种:联合查询(union)。本文我们将系统的讲解多表查询。 笛卡尔积现象 首先,我们想要查询emp表和stu表两个表,按照我们之前的知识栈,我们直接使用…

Qt6.8实现麦克风音频输入音频采集保存wav文件

一.本文目的 实现在Qt中接收麦克风数据并保存为WAV文件,使用QAudioInput来录音,并使用QFile来保存数据到WAV文件。 开发环境:QT6.8 本文用极简代码实现,核心代码只需不到100行。 二.代码实现

K8S学习之基础三十四:K8S之监控Prometheus部署pod版

使用 Kubernetes Pod 的方式部署 Prometheus 是一种常见的方法,尤其是在容器化和微服务架构中。以下是详细的步骤: 1. 创建命名空间(可选) 为了方便管理,可以为 Prometheus 创建一个单独的命名空间。 yaml 复制 a…