欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python查詢MySQL將數(shù)據(jù)寫入Excel

 更新時(shí)間:2020年10月29日 16:09:15   作者:py3study  
這篇文章主要介紹了python如何查詢MySQL將數(shù)據(jù)寫入Excel,幫助大家利用python高效的辦公,感興趣的朋友可以了解下

一、概述

現(xiàn)有一個(gè)用戶表,需要將表數(shù)據(jù)寫入到excel中。

環(huán)境說明

mysql版本:5.7

端口:3306

數(shù)據(jù)庫:test

表名:users

表結(jié)構(gòu)如下:

CREATE TABLE `users` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `username` varchar(50) COLLATE utf8mb4_bin NOT NULL COMMENT '用戶名',
 `password` varchar(255) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '密碼',
 `phone` varchar(20) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '手機(jī)號',
 `email` varchar(255) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '郵箱',
 `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時(shí)間',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;

插入3行數(shù)據(jù)

INSERT INTO `test`.`users` (`id`, `username`, `password`, `phone`, `email`, `create_time`) VALUES ('1', 'xiao', '123', '12345678910', '123@qq.com', '2020-04-10 01:22:07');
INSERT INTO `test`.`users` (`id`, `username`, `password`, `phone`, `email`, `create_time`) VALUES ('2', 'zhang', '123', '12345678910', '123@qq.com', '2020-04-10 01:22:07');
INSERT INTO `test`.`users` (`id`, `username`, `password`, `phone`, `email`, `create_time`) VALUES ('3', 'lisi', '123', '12345678910', '123@qq.com', '2020-04-10 01:22:07');

二、基本寫法

安裝模塊

pip3 install xlwt pymysql

test_excel.py

#!/usr/bin/env python3
# coding: utf-8
import os
import xlwt
import pymysql
import datetime

class MysqlToExcel(object):
  def __init__(self):
    self.host = '10.212.21.92'
    self.user = 'root'
    self.passwd = 'abcd1234'
    self.db_name = 'test'
    self.port = 3306
    self.file_name = 'data.xls'

  def get_query_results(self):
    sql = "select * from test.users"

    conn = pymysql.connect(
      host=self.host,
      user=self.user,
      passwd=self.passwd,
      port=self.port,
      database=self.db_name,
      charset='utf8',
      cursorclass=pymysql.cursors.DictCursor
    )
    cur = conn.cursor() # 創(chuàng)建游標(biāo)
    cur.execute(sql) # 執(zhí)行sql命令
    result = cur.fetchall() # 獲取執(zhí)行的返回結(jié)果
    # print(result)
    cur.close()
    conn.close() # 關(guān)閉mysql 連接
    return result

  def generate_table(self):
    """
    生成excel表格
    :return:
    """
    # 刪除已存在的文件
    if os.path.exists(self.file_name):
      os.remove(self.file_name)

    result = self.get_query_results()
    # print(result)
    if not result:
      print("查詢結(jié)果為空")
      return False

    # 創(chuàng)建excel對象
    f = xlwt.Workbook()
    sheet1 = f.add_sheet('Sheet1', cell_overwrite_ok=True)

    # 列字段
    column_names = ['id','username','password','phone','email']

    # 寫第一行,也就是列所在的行
    for i in range(0, len(column_names)):
      sheet1.write(0, i, column_names[i])

    # 寫入多行
    num = 0 # 計(jì)數(shù)器
    for i in result:
      sheet1.write(num + 1, 0, i['id'])
      sheet1.write(num + 1, 1, i['username'])
      sheet1.write(num + 1, 2, i['password'])
      sheet1.write(num + 1, 3, i['phone'])
      sheet1.write(num + 1, 4, i['email'])
      # 日期轉(zhuǎn)換為字符串
      value = i['create_time'].strftime('%Y-%m-%d %H:%M:%S')
      sheet1.write(num + 1, 5, value)

      num += 1 # 自增1

    # 保存文件
    f.save(self.file_name)

    # 判斷文件是否存在
    if not os.path.exists(self.file_name):
      print("生成excel失敗")
      return False

    print("生成excel成功")
    return True

if __name__ == '__main__':
  MysqlToExcel().generate_table()

執(zhí)行輸出:

查看excel表

三、高級寫法

在基礎(chǔ)寫法中,需要指定表的字段,比如:['id','username','password','phone','email']

如果一個(gè)表有70個(gè)字段怎么辦?一個(gè)寫筆記耗時(shí)間,能不能動態(tài)獲取表字段呢?答案是可以的。

由于我在創(chuàng)建游標(biāo)時(shí),指定了pymysql.cursors.DictCursor,它返回的每一行數(shù)據(jù),都是一個(gè)字典。

因此,通過dict.keys()就可以獲取表字段了。

另外,我還得將查詢結(jié)構(gòu)中非string的轉(zhuǎn)換為string類型。

test_excel.py

#!/usr/bin/env python3
# coding: utf-8
import os
import xlwt
import pymysql
import datetime

class MysqlToExcel(object):
  def __init__(self):
    self.host = '10.212.21.92'
    self.user = 'root'
    self.passwd = 'abcd1234'
    self.db_name = 'test'
    self.port = 3306
    self.file_name = 'data.xls'

  def get_query_results(self):
    sql = "select * from test.users"

    conn = pymysql.connect(
      host=self.host,
      user=self.user,
      passwd=self.passwd,
      port=self.port,
      database=self.db_name,
      charset='utf8',
      cursorclass=pymysql.cursors.DictCursor
    )
    cur = conn.cursor() # 創(chuàng)建游標(biāo)
    cur.execute(sql) # 執(zhí)行sql命令
    result = cur.fetchall() # 獲取執(zhí)行的返回結(jié)果
    # print(result)
    cur.close()
    conn.close() # 關(guān)閉mysql 連接
    return result

  def generate_table(self):
    """
    生成excel表格
    :return:
    """
    # 刪除已存在的文件
    if os.path.exists(self.file_name):
      os.remove(self.file_name)

    result = self.get_query_results()
    # print(result)
    if not result:
      print("查詢結(jié)果為空")
      return False

    # 創(chuàng)建excel對象
    f = xlwt.Workbook()
    sheet1 = f.add_sheet('Sheet1', cell_overwrite_ok=True)

    # 第一行結(jié)果
    row0 = result[0]
    # 列字段
    column_names = list(row0)

    # 寫第一行,也就是列所在的行
    for i in range(0, len(row0)):
      sheet1.write(0, i, column_names[i])

    # 寫入多行
    # 行坐標(biāo),從第2行開始,也是1
    for row_id in range(1, len(result) + 1):
      # 列坐標(biāo)
      for col_id in range(len(column_names)):
        # 寫入的值
        value = result[row_id - 1][column_names[col_id]]
        # 判斷為日期時(shí)
        if isinstance(value, datetime.datetime):
          value = result[row_id - 1][column_names[col_id]].strftime('%Y-%m-%d %H:%M:%S')

        # 寫入表格
        sheet1.write(row_id, col_id, value)

    # 保存文件
    f.save(self.file_name)

    # 判斷文件是否存在
    if not os.path.exists(self.file_name):
      print("生成excel失敗")
      return False

    print("生成excel成功")
    return True

if __name__ == '__main__':
  MysqlToExcel().generate_table()

執(zhí)行腳本,結(jié)果同上!

四、自適應(yīng)寬度

上面表格看著不美觀,寬度沒有自適應(yīng)。

解決方法:

增加一個(gè)方法,獲取寬度

def get_maxlength(self,value, col):
  """
  獲取value最大占位長度,用于確定導(dǎo)出的xlsx文件的列寬
  col : 表頭,也參與比較,解決有時(shí)候表頭過長的問題
  """
  # 長度列表
  len_list = []
  # 表頭長度
  width = 256 * (len(col) + 1)
  len_list.append(width)

  # 數(shù)據(jù)長度
  if len(value) >= 10:
    width = 256 * (len(value) + 1)
    len_list.append(width)

  return max(len_list)

完整代碼如下:

#!/usr/bin/env python3
# coding: utf-8
import os
import xlwt
import pymysql
import datetime

class MysqlToExcel(object):
  def __init__(self):
    self.host = '10.212.21.92'
    self.user = 'root'
    self.passwd = 'abcd1234'
    self.db_name = 'test'
    self.port = 3306
    self.file_name = 'data.xls'

  def get_query_results(self):
    sql = "select * from test.users"

    conn = pymysql.connect(
      host=self.host,
      user=self.user,
      passwd=self.passwd,
      port=self.port,
      database=self.db_name,
      charset='utf8',
      cursorclass=pymysql.cursors.DictCursor
    )
    cur = conn.cursor() # 創(chuàng)建游標(biāo)
    cur.execute(sql) # 執(zhí)行sql命令
    result = cur.fetchall() # 獲取執(zhí)行的返回結(jié)果
    # print(result)
    cur.close()
    conn.close() # 關(guān)閉mysql 連接
    return result

  def get_maxlength(self,value, col):
    """
    獲取value最大占位長度,用于確定導(dǎo)出的xlsx文件的列寬
    col : 表頭,也參與比較,解決有時(shí)候表頭過長的問題
    """
    # 長度列表
    len_list = []
    # 表頭長度
    width = 256 * (len(col) + 1)
    len_list.append(width)

    # 數(shù)據(jù)長度
    if len(value) >= 10:
      width = 256 * (len(value) + 1)
      len_list.append(width)

    return max(len_list)


  def generate_table(self):
    """
    生成excel表格
    :return:
    """
    # 刪除已存在的文件
    if os.path.exists(self.file_name):
      os.remove(self.file_name)

    result = self.get_query_results()
    # print(result)
    if not result:
      print("查詢結(jié)果為空")
      return False

    # 創(chuàng)建excel對象
    f = xlwt.Workbook()
    sheet1 = f.add_sheet('Sheet1', cell_overwrite_ok=True)

    # 第一行結(jié)果
    row0 = result[0]
    # 列字段
    column_names = list(row0)

    # 寫第一行,也就是列所在的行
    for i in range(0, len(row0)):
      sheet1.write(0, i, column_names[i])

    # 寫入多行
    # 行坐標(biāo),從第2行開始,也是1
    for row_id in range(1, len(result) + 1):
      # 列坐標(biāo)
      for col_id in range(len(column_names)):
        # 寫入的值
        value = result[row_id - 1][column_names[col_id]]
        # 判斷為日期時(shí)
        if isinstance(value, datetime.datetime):
          value = result[row_id - 1][column_names[col_id]].strftime('%Y-%m-%d %H:%M:%S')

        # 獲取表格對象
        col = sheet1.col(col_id)
        if value:
          if isinstance(value, int):
            value = str(value)

          # 獲取寬度
          width = self.get_maxlength(value,column_names[col_id])

          # 設(shè)置寬度
          col.width = width
        # 寫入表格
        sheet1.write(row_id, col_id, value)

    # 保存文件
    f.save(self.file_name)

    # 判斷文件是否存在
    if not os.path.exists(self.file_name):
      print("生成excel失敗")
      return False

    print("生成excel成功")
    return True

if __name__ == '__main__':
  MysqlToExcel().generate_table()

執(zhí)行腳本,查看excel

 

以上就是python查詢MySQL將數(shù)據(jù)寫入Excel的詳細(xì)內(nèi)容,更多關(guān)于python 查詢MySQL的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解anaconda安裝步驟

    詳解anaconda安裝步驟

    這篇文章主要介紹了詳解anaconda安裝步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Python實(shí)現(xiàn)新版正方系統(tǒng)滑動驗(yàn)證碼識別

    Python實(shí)現(xiàn)新版正方系統(tǒng)滑動驗(yàn)證碼識別

    這篇文章主要介紹了基于Python實(shí)現(xiàn)新版正方系統(tǒng)滑動驗(yàn)證碼識別算法和方案,文中示例代碼對我們的學(xué)習(xí)和工作有一定的幫助,感興趣的可以了解一下
    2021-12-12
  • pandas重置索引標(biāo)簽的實(shí)現(xiàn)示例

    pandas重置索引標(biāo)簽的實(shí)現(xiàn)示例

    在使用Pandas進(jìn)行數(shù)據(jù)處理時(shí),有時(shí)候我們可能會需要對數(shù)據(jù)進(jìn)行重置索引的操作,本文主要介紹了pandas重置索引標(biāo)簽的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-04-04
  • 使用Python寫一個(gè)貪吃蛇游戲?qū)嵗a

    使用Python寫一個(gè)貪吃蛇游戲?qū)嵗a

    這篇文章主要介紹了使用Python寫一個(gè)貪吃蛇游戲?qū)嵗a,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-08-08
  • Django文件存儲 默認(rèn)存儲系統(tǒng)解析

    Django文件存儲 默認(rèn)存儲系統(tǒng)解析

    這篇文章主要介紹了Django文件存儲 默認(rèn)存儲系統(tǒng)解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • python創(chuàng)建與遍歷二叉樹的方法實(shí)例

    python創(chuàng)建與遍歷二叉樹的方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于python創(chuàng)建與遍歷二叉樹的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • python字符串常用方法

    python字符串常用方法

    這篇文章主要介紹了python字符串常用方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • Python 多線程不加鎖分塊讀取文件的方法

    Python 多線程不加鎖分塊讀取文件的方法

    今天小編就為大家分享一篇Python 多線程不加鎖分塊讀取文件的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • 基于Python socket實(shí)現(xiàn)簡易網(wǎng)絡(luò)聊天室

    基于Python socket實(shí)現(xiàn)簡易網(wǎng)絡(luò)聊天室

    本文主要介紹了基于Python socket實(shí)現(xiàn)簡易網(wǎng)絡(luò)聊天室,本文將通過pyqt5作為桌面應(yīng)用框架,socket作為網(wǎng)絡(luò)編程的框架,從而實(shí)現(xiàn)包括客戶端和服務(wù)端的網(wǎng)絡(luò)聊天室的GUI應(yīng)用,需要的可以參考一下
    2022-07-07
  • Python的函數(shù)的一些高階特性

    Python的函數(shù)的一些高階特性

    這篇文章主要介紹了Python的函數(shù)的一些高階特性,包括函數(shù)名用作變量等一些小技巧,需要的朋友可以參考下
    2015-04-04

最新評論