背景:将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相关推荐

  1. python 列表写入excel_Python将MySQL表数据写入excel

    背景:将mysql表查询结果写入excel. 1.使用sqlyog工具将查询结果导出到Excel.xml中,用excel打开发现:因为text字段中有回车换行操作,显示结果行是乱的. 2.用mysql ...

  2. python 写入excel数据xlwt_用python包xlwt将数据写入Excel中

    一般用两种格式的数据写入,不多说放上demo. 1.列表形式写入 import xlwt def data_write(file_path, datas): f = xlwt.Workbook() s ...

  3. mysql写到excel_使用Python从 MySQL写数据到Excel

    直接上代码:#!/usr/bin/env python #coding:utf-8 import xlwt import MySQLdb import datetime database = MySQ ...

  4. python写入excel换行_使用Python使用xlsxwriter读取数据写入Excel软件不同sheet表格中...

    [环境介绍] 系统环境:win10 + python 3.5.4 + PyCharm [背景描述] 需求:将数据库和主机查询的数据信息写入到Excel表格中 [采集数据脚本信息] 数据库层面 列子:磁 ...

  5. Python 基于Python从mysql表读取千万数据实践

    基于Python 从mysql表读取千万数据实践   by:授客 QQ:1033553122 场景:   有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...

  6. 我是如何把python爬虫获取到的数据写入Excel的?

    如何将爬虫获取的数据写入Excel,这一点我在爬虫文章几乎都是采用这种方式来进行操作的 写入Excel的目的是为了后续更加方便的使用pandas对数据进行清洗.筛选.过滤等操作. 为进一步数据研究.可 ...

  7. python实现将数据写入Excel文件中

    将数据写入Excel文件中,用python实现起来非常的简单,下面一步步地教大家. 一.导入excel表格文件处理函数 import xlwt 注意,这里的xlwt是python的第三方模块,需要下载 ...

  8. 如何用python将数据写入Excel文件中

    如何用python将数据写入Excel文件中 将数据写入Excel文件中,用python实现起来非常的简单,下面一步步地教大家. 一.导入excel表格文件处理函数 import xlwt 注意,这里 ...

  9. R语言write.xlsx函数将数据写入Excel文件:写入Excel文件并自定义表单的名称、将数据写入Excel文件新的表单(sheet)中、将文件保存为xls文件格式(而不是xlsx)

    R语言write.xlsx函数将数据写入Excel文件:写入Excel文件并自定义表单的名称.将数据写入Excel文件新的表单(sheet)中.将文件保存为xls文件格式(而不是xlsx) 目录

最新文章

  1. VC两个线程协作运行,轮流运行的
  2. 《应届生求职面试全攻略》学习笔记(三)——面试题目分类讲解
  3. 腾讯qq帮你装silverlight
  4. 爬虫python教程百度云_Python爬虫比较基础的教程视频百度云网盘下载
  5. 用户输入一个字符串,将下标为偶数的字符提出来合并成一个新的字符串A,再将下标为奇数的字符提出来合并成一个新的字符串B,再将字符串A和B连接起来并输出。
  6. SIPp web frontend(2)
  7. 修改eclipse配置文件properties编码格式
  8. TensorFlow tf.keras.losses.MeanSquaredError
  9. IOS使用pods初次加载出现Pods-resources.sh: Permission denied错误的解决方案
  10. eclipse部署web没部署成功的问题
  11. GIS-python学习
  12. 23.Linux/Unix 系统编程手册(上) -- 定时器与休眠
  13. 14. JavaScript Date(日期)对象
  14. 字母c语言ascii码,c语言ascii码对照表
  15. c++ 获取硬盘序列号serialnumber
  16. 2019深圳杯获奖论文_我校研究生喜获2019年“深圳杯”数学建模挑战赛决赛三等奖...
  17. 调试EasyDarwin开源项目EasyCamera-HK接入海康IPCamera 摄像机所遇到的大坑
  18. R语言数据异常值处理
  19. 学会Apache网页与安全的优化,让你的技术更加胜人一筹!(网页压缩与缓存、隐藏版本信息与配置防盗链)
  20. Spring Boot电商项目54:订单模块三:【前台:订单详情】接口;

热门文章

  1. VC:其他控件(CProgressCtrl、CScrollBar、CDateTimeCtrl、CMonthCalCtrl)
  2. 备忘录吕吕没有备忘录十新建_一份备忘单,可帮助您记住CSS自定义属性
  3. 编程术语_伟大的编程术语烘烤
  4. 电子白板 矢量 编码_当涉及白板编码采访时,请记住准备
  5. PL/SQL编程:用Loop-exit-when-end循环算出5的阶乘
  6. java 接口工程_Java工程师(15)抽象类与接口
  7. java开发培训好学习吗?难度大不大?
  8. 什么是AngularJS?它有哪些特性?
  9. Android -- Fragment注意事项
  10. 气温上升影响数据中心节能