Python将MySQL表数据写入excel
背景:将mysql表查询结果写入excel。
1.使用sqlyog工具将查询结果导出到Excel.xml中,用excel打开发现:因为text字段中有回车换行操作,显示结果行是乱的。
2.用mysql -uadmin -p -h -P -NBe"select * from tb;" >>a.txt 导出。发现用TXT查看还是excel查看也是乱序。
3.下面是用Python的xlsxwriter模块写入excel文件。
数据库表:
CREATE TABLE `s1` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) DEFAULT NULL,
`local` text,
`mobile` int(11) DEFAULT NULL,
`CreateTime` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1
表查询:
local字段:text类型,里面有空格、空行,换行操作
----------------------------------------------------------------------------------------------------------------------------------
------------------------------------------------------------------------------------------------------------------------------------------
Python脚本内容:
[root@monitor2]# vim select.py
#!/usr/bin/env python
#-*- coding: utf8 -*-
import MySQLdb
import string
import xlsxwriter
import datetime
# 定义时间标志变量
sheet_time = datetime.datetime.now()
sheet_mark = sheet_time.strftime('%Y-%m-%d')
book_mark = sheet_time.strftime('%Y%m%d')
# 定义输出excel文件名
workbook = xlsxwriter.Workbook('select_'+book_mark+'.xlsx')
# 定义sheet的名字
worksheet = workbook.add_worksheet(sheet_mark)
# 定义sheet中title的字体format
bold = workbook.add_format({'bold': True})
# 定义sql查询命令
cmd="select * from db1.s1;"
# 定义链接mysql的用户信息 字典
Loginfo = {'USER':'admin', 'PSWD':'admin', 'HOST':'10.10.60.105', 'PORT':4001}
# 调用MySQLdb模块 链接 mysql
conn=MySQLdb.connect(host=Loginfo['HOST'],user=Loginfo['USER'],passwd=Loginfo['PSWD'],port=Loginfo['PORT'],charset='utf8')
cur=conn.cursor()
cur.execute(cmd)
# 查询数据结果和字段名字 赋值给两个变量
result = cur.fetchall()
fields = cur.description # get column name
# 将结果写入excel中
# 定义title的坐标:row=0,col=0~字段总数 也就是excel的第一行:0,0 ~ 0,len(fields)
# 关于fields的结果如下图:通过fields[field][0] 获取字段名
for field in range(0,len(fields)):
worksheet.write(0,field,fields[field][0],bold)
#数据坐标0,0 ~ row,col row取决于:result的行数;col取决于fields的总数
for row in range(1,len(result)+1):
for col in range(0,len(fields)):
worksheet.write(row,col,u'%s' % result[row-1][col])
cur.close()
conn.close()
workbook.close()
输出excel结果如下图:
--------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------
点开Local:格式不乱
-------------------------------------------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------------------------------------------
转载于:https://www.cnblogs.com/cuisi/p/6249493.html
Python将MySQL表数据写入excel相关推荐
- python 列表写入excel_Python将MySQL表数据写入excel
背景:将mysql表查询结果写入excel. 1.使用sqlyog工具将查询结果导出到Excel.xml中,用excel打开发现:因为text字段中有回车换行操作,显示结果行是乱的. 2.用mysql ...
- python 写入excel数据xlwt_用python包xlwt将数据写入Excel中
一般用两种格式的数据写入,不多说放上demo. 1.列表形式写入 import xlwt def data_write(file_path, datas): f = xlwt.Workbook() s ...
- mysql写到excel_使用Python从 MySQL写数据到Excel
直接上代码:#!/usr/bin/env python #coding:utf-8 import xlwt import MySQLdb import datetime database = MySQ ...
- python写入excel换行_使用Python使用xlsxwriter读取数据写入Excel软件不同sheet表格中...
[环境介绍] 系统环境:win10 + python 3.5.4 + PyCharm [背景描述] 需求:将数据库和主机查询的数据信息写入到Excel表格中 [采集数据脚本信息] 数据库层面 列子:磁 ...
- Python 基于Python从mysql表读取千万数据实践
基于Python 从mysql表读取千万数据实践 by:授客 QQ:1033553122 场景: 有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...
- 我是如何把python爬虫获取到的数据写入Excel的?
如何将爬虫获取的数据写入Excel,这一点我在爬虫文章几乎都是采用这种方式来进行操作的 写入Excel的目的是为了后续更加方便的使用pandas对数据进行清洗.筛选.过滤等操作. 为进一步数据研究.可 ...
- python实现将数据写入Excel文件中
将数据写入Excel文件中,用python实现起来非常的简单,下面一步步地教大家. 一.导入excel表格文件处理函数 import xlwt 注意,这里的xlwt是python的第三方模块,需要下载 ...
- 如何用python将数据写入Excel文件中
如何用python将数据写入Excel文件中 将数据写入Excel文件中,用python实现起来非常的简单,下面一步步地教大家. 一.导入excel表格文件处理函数 import xlwt 注意,这里 ...
- R语言write.xlsx函数将数据写入Excel文件:写入Excel文件并自定义表单的名称、将数据写入Excel文件新的表单(sheet)中、将文件保存为xls文件格式(而不是xlsx)
R语言write.xlsx函数将数据写入Excel文件:写入Excel文件并自定义表单的名称.将数据写入Excel文件新的表单(sheet)中.将文件保存为xls文件格式(而不是xlsx) 目录
最新文章
- VC两个线程协作运行,轮流运行的
- 《应届生求职面试全攻略》学习笔记(三)——面试题目分类讲解
- 腾讯qq帮你装silverlight
- 爬虫python教程百度云_Python爬虫比较基础的教程视频百度云网盘下载
- 用户输入一个字符串,将下标为偶数的字符提出来合并成一个新的字符串A,再将下标为奇数的字符提出来合并成一个新的字符串B,再将字符串A和B连接起来并输出。
- SIPp web frontend(2)
- 修改eclipse配置文件properties编码格式
- TensorFlow tf.keras.losses.MeanSquaredError
- IOS使用pods初次加载出现Pods-resources.sh: Permission denied错误的解决方案
- eclipse部署web没部署成功的问题
- GIS-python学习
- 23.Linux/Unix 系统编程手册(上) -- 定时器与休眠
- 14. JavaScript Date(日期)对象
- 字母c语言ascii码,c语言ascii码对照表
- c++ 获取硬盘序列号serialnumber
- 2019深圳杯获奖论文_我校研究生喜获2019年“深圳杯”数学建模挑战赛决赛三等奖...
- 调试EasyDarwin开源项目EasyCamera-HK接入海康IPCamera 摄像机所遇到的大坑
- R语言数据异常值处理
- 学会Apache网页与安全的优化,让你的技术更加胜人一筹!(网页压缩与缓存、隐藏版本信息与配置防盗链)
- Spring Boot电商项目54:订单模块三:【前台:订单详情】接口;
热门文章
- VC:其他控件(CProgressCtrl、CScrollBar、CDateTimeCtrl、CMonthCalCtrl)
- 备忘录吕吕没有备忘录十新建_一份备忘单,可帮助您记住CSS自定义属性
- 编程术语_伟大的编程术语烘烤
- 电子白板 矢量 编码_当涉及白板编码采访时,请记住准备
- PL/SQL编程:用Loop-exit-when-end循环算出5的阶乘
- java 接口工程_Java工程师(15)抽象类与接口
- java开发培训好学习吗?难度大不大?
- 什么是AngularJS?它有哪些特性?
- Android -- Fragment注意事项
- 气温上升影响数据中心节能