python3查询数据库并生成excel报表

#!/usr/bin/env python3
#encoding=UTF-8

import os
import time
import xlwt

hostIp = 'xxx.xxx.xxx.xx'
user = 'user0001'
passwd = 'xxxx'
db = 'db01'

sqlStr1 = 'SELECT timeout_day as 逾期天数,COUNT(1) as 统计次数 FROM t_order_info where status in (7,9) GROUP BY timeout_day HAVING timeout_day <> 0;'

def createTable(selectSql,tableName):
    #连接数据库,执行sql
    results = os.popen('mysql -h'+hostIp+' -u'+user+' -p'+passwd+' -D'+db+' -e "'+selectSql+'"').read().strip().split('\n')
    #获取列名
    columnName = results[0].split('\t')

    #创建一个excel工作簿,编码utf-8,表格中支持中文
    wb=xlwt.Workbook(encoding='utf-8')
    #创建一个sheet
    sheet=wb.add_sheet('sheet 1')

    #获取行数
    rows = len(results)
    #获取列数
    columns = len(columnName)

    #创建格式style
    style = xlwt.XFStyle()
    #创建font,设置字体
    font = xlwt.Font()
    #字体格式
    font.name = 'Times New Roman'
    #将字体font,应用到格式style
    style.font = font
    #创建alignment,居中
    alignment = xlwt.Alignment() 
    #居中
    alignment.horz = xlwt.Alignment.HORZ_CENTER
    #应用到格式style
    style.alignment = alignment

    
    style1 = xlwt.XFStyle()
    font1 = xlwt.Font()
    font1.name = 'Times New Roman'
    #字体颜色(绿色)
    #font1.colour_index = 3 
    #字体加粗
    font1.bold = True
    style1.font = font1
    style1.alignment = alignment

    for i in range(columns):
        #设置列的宽度
        sheet.col(i).width = 5000

    #插入列名
    for i in range(columns):
        
        sheet.write(0,i,columnName[i],style1) 

    #将数据插入表格
    for i in range(1,rows):
        for j in range(columns):
            sheet.write(i,j,results[i].split('\t')[j],style)
    
    #保存表格,并命名为‘xxxx’户.xls
    wb.save(tableName)


#获取当前时间
excelTime = time.strftime("%Y%m%d") 

createTable(sqlStr1,excelTime+'逾期统计.xls')

 

转载于:https://www.cnblogs.com/vijayfly/p/6925020.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Python可以轻松地从Oracle数据库中读取数据生成报表。以下是一些常用的Python库和步骤: 1. 安装必要的Python库:cx_Oracle、pandas、openpyxl等。 2. 连接到Oracle数据库,可以使用cx_Oracle库连接到Oracle数据库。 3. 通过SQL查询从Oracle数据库中获取数据,使用pandas库可以将查询结果转换为DataFrame对象。 4. 使用openpyxl等库将数据写入Excel文件中。 以下是一个示例代码,用于从Oracle数据库中获取数据并将其写入Excel文件中: ```python import cx_Oracle import pandas as pd from openpyxl import Workbook # 连接Oracle数据库 conn = cx_Oracle.connect('username/password@host:port/service_name') # SQL查询语句 sql = 'SELECT * FROM table_name' # 获取查询结果并转换为DataFrame对象 df = pd.read_sql(sql, conn) # 创建Excel文件 wb = Workbook() # 选择第一个工作 ws = wb.active # 将DataFrame对象写入Excel文件中 for r in dataframe_to_rows(df, index=False, header=True): ws.append(r) # 保存Excel文件 wb.save('report.xlsx') # 关闭数据库连接 conn.close() ``` 以上代码中,需要替换的部分包括: - `username`和`password`:Oracle数据库的用户名和密码 - `host`:Oracle数据库的主机名或IP地址 - `port`:Oracle数据库的端口号 - `service_name`:Oracle数据库的服务名称 - `table_name`:需要查询的名 - `report.xlsx`:生成Excel文件名 当然,如果你需要生成其他格式的报表,可以使用不同的Python库来实现。例如,使用matplotlib库可以生成,使用reportlab库可以生成PDF报表等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值