用python生成mysql数据库结构文档

作者:henghenghahei_3 时间:2021-05-15 12:04:33 

最近因为项目原因需要编写数据库设计文档,但是由于数据表太多,手动编写耗费的时间太久,所以搞了一个简单的脚本快速生成数据库结构,保存到word文档中。

安装pymysql和document

pip install pymysql
pip install document

脚本

# -*- coding: utf-8 -*-
import pymysql
from docx import Document
from docx.shared import Pt
from docx.oxml.ns import qn

db = pymysql.connect(host='127.0.0.1', #数据库服务器IP
                        port=3306,
                        user='root',
                        passwd='123456',
                        db='test_db') #数据库名称)
#根据表名查询对应的字段相关信息
def query(tableName):
   #打开数据库连接
   cur = db.cursor()
   sql = "select b.COLUMN_NAME,b.COLUMN_TYPE,b.COLUMN_COMMENT from (select * from information_schema.`TABLES`  where TABLE_SCHEMA='test_db') a right join(select * from information_schema.`COLUMNS` where TABLE_SCHEMA='test_db_test') b on a.TABLE_NAME = b.TABLE_NAME where a.TABLE_NAME='" + tableName+"'"
   cur.execute(sql)
   data = cur.fetchall()
   cur.close
   return data
#查询当前库下面所有的表名,表名:tableName;表名+注释(用于填充至word文档):concat(TABLE_NAME,'(',TABLE_COMMENT,')')
def queryTableName():
   cur = db.cursor()
   sql = "select TABLE_NAME,concat(TABLE_NAME,'(',TABLE_COMMENT,')') from information_schema.`TABLES`  where TABLE_SCHEMA='test_db_test'"
   cur.execute(sql)
   data = cur.fetchall()
   return data
#将每个表生成word结构,输出到word文档
def generateWord(singleTableData,document,tableName):
   p=document.add_paragraph()
   p.paragraph_format.line_spacing=1.5 #设置该段落 行间距为 1.5倍
   p.paragraph_format.space_after=Pt(0) #设置段落 段后 0 磅
   #document.add_paragraph(tableName,style='ListBullet')
   r=p.add_run('\n'+tableName)
   r.font.name=u'宋体'
   r.font.size=Pt(12)
   table = document.add_table(rows=len(singleTableData)+1, cols=3,style='Table Grid')
   table.style.font.size=Pt(11)
   table.style.font.name=u'Calibri'
   #设置表头样式
   #这里只生成了三个表头,可通过实际需求进行修改
   for i in ((0,'NAME'),(1,'TYPE'),(2,'COMMENT')):
       run = table.cell(0,i[0]).paragraphs[0].add_run(i[1])
       run.font.name = 'Calibri'
       run.font.size = Pt(11)
       r = run._element
       r.rPr.rFonts.set(qn('w:eastAsia'), '宋体')

for i in range(len(singleTableData)):
       #设置表格内数据的样式
       for j in range(len(singleTableData[i])):
           run = table.cell(i+1,j).paragraphs[0].add_run(singleTableData[i][j])
           run.font.name = 'Calibri'
           run.font.size = Pt(11)
           r = run._element
           r.rPr.rFonts.set(qn('w:eastAsia'), '宋体')
       #table.cell(i+1, 0).text=singleTableData[i][1]
       #table.cell(i+1, 1).text=singleTableData[i][2]
       #table.cell(i+1, 2).text=singleTableData[i][3]

if __name__ == '__main__':
   #定义一个document
   document = Document()
   #设置字体默认样式
   document.styles['Normal'].font.name = u'宋体'
   document.styles['Normal']._element.rPr.rFonts.set(qn('w:eastAsia'), u'宋体')
   #获取当前库下所有的表名信息和表注释信息
   tableList = queryTableName()
   #循环查询数据库,获取表字段详细信息,并调用generateWord,生成word数据
   #由于时间匆忙,我这边选择的是直接查询数据库,执行了100多次查询,可以进行优化,查询出所有的表结构,在代码里面将每个表结构进行拆分
   for singleTableName in tableList:
       data = query(singleTableName[0])
       generateWord(data,document,singleTableName[1])
   #保存至文档
   document.save('数据库设计.docx')

生成的word文档预览

用python生成mysql数据库结构文档

来源:https://blog.csdn.net/henghenghahei_3/article/details/122578797

标签:python,mysql,文档
0
投稿

猜你喜欢

  • 发个js从样式表取值的函数

    2008-05-20 12:23:00
  • CSS缩写可以有效的缩小CSS文件的体积

    2009-01-13 18:06:00
  • Keras官方中文文档:性能评估Metrices详解

    2023-07-15 00:27:40
  • Laravel配置全局公共函数的方法步骤

    2023-11-15 01:20:42
  • 数字人整合动网论坛的方法

    2009-05-29 18:23:00
  • 斜角滑动门导航条 DIV+CSS

    2008-07-19 15:45:00
  • asp实现在线人数统计代码

    2008-08-10 18:35:00
  • asp如何实现对Session 数组的定义和调用?

    2010-05-18 18:40:00
  • thinkphp6如何使用中间件记录行为日志

    2023-06-13 14:43:44
  • asp彩色验证码的制作详解

    2007-09-18 13:22:00
  • 利用aspjpeg组件自动生成产品缩略图asp源代码

    2007-08-10 10:14:00
  • PHP邮件发送类PHPMailer用法实例详解

    2023-11-19 16:31:17
  • Python中关于函数的具体用法范例以及介绍

    2023-06-04 19:48:28
  • SQL Server 数据库备份和还原认识和总结(二)

    2012-10-07 10:52:52
  • python文件和目录操作方法大全(含实例)

    2021-11-11 14:10:29
  • 利用phpmyadmin设置mysql的权限方法

    2023-11-24 02:12:46
  • php文章内容分页并生成相应的htm静态页面代码

    2023-07-23 23:48:20
  • Python3 利用face_recognition实现人脸识别的方法

    2023-11-05 05:08:02
  • js表单检测数字

    2007-10-12 13:52:00
  • AJAX实现延时顺序请求多个URL

    2007-12-06 18:32:00
  • asp之家 网络编程 m.aspxhome.com