在django里用xlwt作EXCEL导出功能

参考了以前kevin的代码,搞起来快呀,哈哈哈,,阿里亚多。。。。

代码的意思比较明白,不注释,几乎自解释。。。

就是定义EXCEL时,比较硬生生的,一步一步没有快捷的方法。

另外就是取时间出来时,如果时区不对,就要自已来转换下。另外,数字型之类的要转换为字符型,不然,又会出错。。。

def ExportContentByJiraVersion(request, site_name=None, jira_version=None):
    response = HttpResponse(content_type='application/vnd.ms-excel')
    response[
        'Content-Disposition'] = 'attachment;filename={0}-{1}.xls'.format(site_name, jira_version)
    wb = xlwt.Workbook(encoding='utf-8')
    sheet_prd = wb.add_sheet('PRD')
    sheet_uat = wb.add_sheet('UAT')
    sheet_fat = wb.add_sheet('FAT')

    style_heading = xlwt.easyxf("""
        font:
            name Arial,
            colour_index white,
            bold on,
            height 0xA0;
        align:
            wrap off,
            vert center,
            horiz center;
        pattern:
            pattern solid,
            fore-colour 0x19;
        borders:
            left THIN,
            right THIN,
            top THIN,
            bottom THIN;
        """
                                )
    style_body = xlwt.easyxf("""
        font:
            name Arial,
            bold off,
            height 0XA0;
        align:
            wrap on,
            vert center,
            horiz left;
        borders:
            left THIN,
            right THIN,
            top THIN,
            bottom THIN;
        """
                             )
    style_green = xlwt.easyxf(" pattern: pattern solid,fore-colour 0x11;")
    style_red = xlwt.easyxf(" pattern: pattern solid,fore-colour 0x0A;")
    fmts = [
        'M/D/YY',
        'D-MMM-YY',
        'D-MMM',
        'MMM-YY',
        'h:mm AM/PM',
        'h:mm:ss AM/PM',
        'h:mm',
        'h:mm:ss',
        'M/D/YY h:mm',
        'mm:ss',
        '[h]:mm:ss',
        'mm:ss.0',
    ]
    style_body.num_format_str = fmts[0]
    # 1st line
    sheet_prd.write(0, 0, '发布单', style_heading)
    sheet_prd.write(0, 1, '组件', style_heading)
    sheet_prd.write(0, 2, '环境', style_heading)
    sheet_prd.write(0, 3, '进度', style_heading)
    sheet_prd.write(0, 4, 'JIRA问题号', style_heading)
    sheet_prd.write(0, 5, '操作用户', style_heading)
    sheet_prd.write(0, 6, '时间', style_heading)

    row = 1
    contents = XXX.objects.filter(site_name__name=site_name).filter(jira_issue_version=jira_version)\
        .filter(deploy_status='PRD')
    for content in contents:
        sheet_prd.write(row, 0, content.name, style_body)
        sheet_prd.write(row, 1, content.app_name.name, style_body)
        sheet_prd.write(row, 2, content.deploy_status, style_body)
        if content.deploy_progress == u'已发布':
            sheet_prd.write(row, 3, content.deploy_progress, style_green)
        else:
            sheet_prd.write(row, 3, content.deploy_progress, style_red)
        sheet_prd.write(row, 4, content.jira_issue_no, style_body)
        sheet_prd.write(row, 5, str(content.create_user), style_body)
        sheet_prd.write(row, 6, str(content.change_date + timedelta(hours=8)), style_body)

        # 第一行加宽
        sheet_prd.col(0).width = 100 * 50
        sheet_prd.col(1).width = 200 * 50
        sheet_prd.col(2).width = 50 * 50
        sheet_prd.col(3).width = 50 * 50
        sheet_prd.col(4).width = 200 * 50
        sheet_prd.col(5).width = 50 * 50
        sheet_prd.col(6).width = 200 * 50
        row += 1

    # 1st line
    sheet_uat.write(0, 0, '发布单', style_heading)
    sheet_uat.write(0, 1, '组件', style_heading)
    sheet_uat.write(0, 2, '环境', style_heading)
    sheet_uat.write(0, 3, '进度', style_heading)
    sheet_uat.write(0, 4, 'JIRA问题号', style_heading)
    sheet_uat.write(0, 5, '操作用户', style_heading)
    sheet_uat.write(0, 6, '时间', style_heading)

    row = 1
    contents = XXX.objects.filter(site_name__name=site_name).filter(jira_issue_version=jira_version)\
        .filter(deploy_status='UAT')
    for content in contents:
        sheet_uat.write(row, 0, content.name, style_body)
        sheet_uat.write(row, 1, content.app_name.name, style_body)
        sheet_uat.write(row, 2, content.deploy_status, style_body)
        if content.deploy_progress == u'已发布':
            sheet_uat.write(row, 3, content.deploy_progress, style_green)
        else:
            sheet_uat.write(row, 3, content.deploy_progress, style_red)
        sheet_uat.write(row, 4, content.jira_issue_no, style_body)
        sheet_uat.write(row, 5, str(content.create_user), style_body)
        sheet_uat.write(row, 6, str(content.change_date + timedelta(hours=8)), style_body)

        # 第一行加宽
        sheet_uat.col(0).width = 100 * 50
        sheet_uat.col(1).width = 200 * 50
        sheet_uat.col(2).width = 50 * 50
        sheet_uat.col(3).width = 50 * 50
        sheet_uat.col(4).width = 200 * 50
        sheet_uat.col(5).width = 50 * 50
        sheet_uat.col(6).width = 200 * 50
        row += 1

    output = StringIO.StringIO()
    wb.save(output)
    output.seek(0)
    response.write(output.getvalue())
    return response

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值