zoukankan      html  css  js  c++  java
  • 使用python处理Excel,Excel中一行数据生产一个Excel文件

    应用场景:比如说收到一个文件,文件里面有几百个用户,需要按照一定的格式每一个用户生成一个Excel文件

    需要生成这样结果:

    每个文件格式如下:

    代码如下:

    # -*- coding: utf-8 -*-
    """
    Created on Tue Apr 28 15:16:14 2020
    
    @author: Admin
    """
    #导入模块
    import pandas as pd
    import numpy as np
    import xlrd  #读Excel
    import xlwt  #将内容写进Excel
    
    #打开excel文件1  
    workbook = xlrd.open_workbook(r'F:\python\test\bb_6c.xlsx')   
    sheet = workbook.sheet_by_index(0)  
    rows = [sheet.row_values(row,0,14) for row in range(sheet.nrows)]
    name_lists = {}   
    for r in rows:
        #因为我们是根据姓名来切分,姓名在第二列。所以这里是r[1]
        if r[1] not in name_lists:
            name_lists[r[1]] = []
        name_lists[r[1]].append(r)
    
    #打开Excel文件2
    workbook =xlrd.open_workbook(r'F:\python\test\bb_6p.xlsx')
    sheet1= workbook.sheet_by_index(0)   
    rows1 = [sheet1.row_values(row,0,12) for row in range(sheet1.nrows)]
    name_lists1 = {}   
    for r in rows1:
        #因为我们是根据姓名来切分,姓名在第二列。所以这里是r[0]
        if r[0] not in name_lists1:
            name_lists1[r[0]] = []
        name_lists1[r[0]].append(r)
    
    #写进Excel里面
    for k, k2 in zip(name_lists,name_lists1):
        wb = xlwt.Workbook()
        #新建sheet
        ws = wb.add_sheet(k)
        #设置列宽度 ,其中第一列要宽一些 ,其他的小一些
        ws.col(0).width=8000
        for i in range(1,14):
            ws.col(i).width=3333
        
        #设置加粗
        font = xlwt.Font()
        font.bold = True  #tyle_ziti = xlwt.easyxf('font: bold on')
        #设置背景颜色黄色
        pattern = xlwt.Pattern() # Create the Pattern
        pattern.pattern = xlwt.Pattern.SOLID_PATTERN # May be: NO_PATTERN, SOLID_PATTERN, or 0x00 through 0x12
        pattern.pattern_fore_colour = 5 # May be: 8 through 63. 0 = Black, 1 = White, 2 = Red, 3 = Green, 4 = Blue, 5 = Yellow, 6 = Magenta, 7 = Cyan, 16 = Maroon, 17 = Dark Green, 18 = Dark Blue, 19 = Dark Yellow , almost brown), 20 = Dark Magenta, 21 = Teal, 22 = Light Gray, 23 = Dark Gray, the list goes on...
        
        
        #设置居中 
        alignment = xlwt.Alignment() # Create Alignment
        alignment.horz = xlwt.Alignment.HORZ_CENTER # May be: HORZ_GENERAL, HORZ_LEFT, HORZ_CENTER, HORZ_RIGHT, HORZ_FILLED, HORZ_JUSTIFIED, HORZ_CENTER_ACROSS_SEL, HORZ_DISTRIBUTED
        alignment.vert = xlwt.Alignment.VERT_CENTER # May be: VERT_TOP, VERT_CENTER, VERT_BOTTOM, VERT_JUSTIFIED, VERT_DISTRIBUTED
        
        #设置边框
        borders = xlwt.Borders() # Create Borders
        borders.left = xlwt.Borders.THIN 
    
        
        # May be: NO_LINE, THIN, MEDIUM, DASHED, DOTTED, THICK, DOUBLE, HAIR, MEDIUM_DASHED, THIN_DASH_DOTTED, MEDIUM_DASH_DOTTED, THIN_DASH_DOT_DOTTED, MEDIUM_DASH_DOT_DOTTED, SLANTED_MEDIUM_DASH_DOTTED, or 0x00 through 0x0D.
        borders.right = xlwt.Borders.THIN
        borders.top = xlwt.Borders.THIN
        borders.bottom = xlwt.Borders.THIN
        borders.left_colour = 0x08
        borders.right_colour = 0x08
        borders.top_colour = 0x08
        borders.bottom_colour = 0x08
        
        style1 = xlwt.XFStyle()
        style2 = xlwt.XFStyle()
        style3 = xlwt.XFStyle()
        style4 = xlwt.XFStyle()
        style5 = xlwt.XFStyle()
        style7 = xlwt.XFStyle()
    
     
        
        #1.边框,居中 加粗
        style1.borders=borders
        style1.alignment=alignment
        style1.font=font
        # 2.边框,居中   
        style2.borders=borders
        style2.alignment=alignment
        #3.边框,居中,黄色
        style3.borders=borders
        style3.alignment=alignment 
        style3.pattern=pattern
    
        #4.边框,居中 加粗,黄色
        style4.borders=borders
        style4.alignment=alignment 
        style4.pattern=pattern
        style4.font=font
        
        
        #5,边框
        style5.borders=borders
        
        #
        style7.borders=borders
        style7.alignment=alignment
        style7.num_format_str="0.00%"
        
        #6.合并,换行,底部对齐,设置行高
        style6 = xlwt.XFStyle()
        tall_style = xlwt.easyxf('font:height 1200;') # 36pt,类型小初的字号
        first_row = ws.row(3)
        first_row.set_style(tall_style)
        alignment1 = xlwt.Alignment()
        alignment1.horz = xlwt.Alignment.HORZ_LEFT
        alignment1.vert = xlwt.Alignment.VERT_BOTTOM
        style6.alignment=alignment1
        style6.alignment.wrap = 1
        
        #设置加粗并设置黄底
        #style_ziti_h = xlwt.easyxf('pattern: pattern solid, fore_colour yellow; font: bold on')
        #设置黄底
        #style_h = xlwt.easyxf('pattern: pattern solid, fore_colour yellow')
        # write_merge函数参数 start_row,end_row,start_col,end_col 
        
        #这里先写入表头
        ws.write_merge(0, 0, 0, 13, '欠款明细',style1)   #需要合并write_merge(0, 0, 0, 13,style_ziti),还需要加粗
        ws.write(1, 0, '合同号',style1)    #需要加粗
        ws.write(1, 1, '姓名',style1)
        ws.write(1, 2, '贷款本金',style1)
        ws.write(1, 3, '首次还款日',style1)
        ws.write(1, 4, '分期期数',style1)
        ws.write(1, 5, '已还期数',style1)
        ws.write(1, 6, '未还期数',style1)
        ws.write(1, 7, '每期期款',style1)
        ws.write(1, 8, '未还本金',style1)
        ws.write(1, 9, '月贷款利率%',style1)
        ws.write(1, 10, '未还利息',style1)
        ws.write(1, 11, '未还本息总和',style1)
        ws.write(1, 12, '利息损失',style1)
        ws.write(1, 13, '欠款总额',style1)  #第二行的都需要加粗
        row_idx = 2          
        for i in name_lists[k]:
            col_idx=0
            for j in i :
                ws.write(row_idx,col_idx,j,style3)  #需要黄体
                col_idx=col_idx+1
            row_idx=row_idx+1
            
        ws.write_merge(3, 3,0,13,'欠款计算说明:
    欠款总额=未还本息总和+利息损失;
    未还本息总和=等额本息还款法计算出的每期期款金额*未还期数;
    利息损失=以代偿金额(即应还未还的贷款本息和)为基数,按照银行同期贷款利率4.35%的标准,自完成代偿之日起,计算至实际清偿之日止。'    ,style6 )
        ws.write_merge(4, 4, 0, 3, '附:等额本息还款法计算公式:',style5)  #需要合并write_merge(7, 0, 0, 3)
        ws.write_merge(5, 5, 0, 3, '输入区',style5) #需要合并write_merge(8, 0, 0, 3)
        ws.write(6, 0, '本金',style2)
        ws.write(6, 1, '分期数(月)',style2)
        ws.write(6, 2, '月利率',style2)
        ws.write(6, 3, '年化',style2)  
        ws.write(7, 0, xlwt.Formula('c3'),style2)
        ws.write(7, 1, xlwt.Formula('e3'),style2)
        ws.write(7, 2, xlwt.Formula('j3'),style7)
        ws.write(7, 3, xlwt.Formula('j3*12'),style7)   
        ws.write(9, 0, '合同号',style4)
        ws.write(9, 1, '期数',style4)   #第13行需要黄体加粗
        ws.write(9, 2, '每月还款额',style4)
        ws.write(9, 3, '本月应还本金',style4)
        ws.write(9, 4, '本月应还利息',style4)
        ws.write(9, 5, '已还本息',style4)
        ws.write(9, 6, '未还本息',style4)
        ws.write(9, 7, '应还款日',style4)
        ws.write(9, 8, '完成代偿日',style4)
        ws.write(9, 9, '利息暂计至',style4)
        ws.write(9, 10, '计息天数',style4)
        ws.write(9, 11, '利息损失',style4)
        
        row_bb=10    
        for gg in name_lists1[k2]:
            col_bb=0
            for hh in gg:            
                ws.write(row_bb,col_bb,hh,style2)
                col_bb=col_bb+1
            row_bb=row_bb+1    
            
        ws.write_merge(16, 16, 0, 5, '未还本息合计',style4) #需要合并write_merge(16, 0, 0, 4)
        ws.write(16, 6, xlwt.Formula('l3'),style4)
        ws.write_merge(16, 16,7,10, '利息损失小计',style4)
        ws.write(16, 11, xlwt.Formula('m3'),style4)
        wb.save('F:\python\test\欠款明细-'+k+'.xls')  #如果要固定存在某个文件夹,则可以这样save(r'f:python_to_excel_xlwtcell_width.xls')
        
  • 相关阅读:
    Android Service启动原理分析
    线程池原理分析
    仿EventBus做一个简单的基于订阅发布的事件总线
    EventBus原理以及源代码分析
    Android从点击Launcher图标开始到App打开流程分析
    使用LruCache和DiskLruCache手写一个ImageLoader
    OkHttp2连接池复用原理分析
    OkHttp执行流程源码分析
    Android使用动态代理模仿Retrofit的create方法,使其可以返回任意的接口类型
    Android模仿Retrofit的建造者模式
  • 原文地址:https://www.cnblogs.com/cgmcoding/p/13274233.html
Copyright © 2011-2022 走看看