zoukankan      html  css  js  c++  java
  • Python 分部分项 数据处理 桂柳

    excel格式

    python代码

    import os
    import openpyxl
    from openpyxl import Workbook
    from copy import deepcopy
    from openpyxl.utils import get_column_letter
    
    
    # 原文:https://www.cnblogs.com/liuda9495/p/9039732.html
    
    
    
    workbook2 = Workbook()
    
    
    def create_worksheet(path):
    
        #path='test1.xlsx'
        workbook = openpyxl.load_workbook(path)# 加载excel
        name_list = workbook.sheetnames# 所有sheet的名字
        
        
        for index, value in enumerate(name_list):
            print(index, value)    
            
            worksheet = workbook[name_list[index]]# 读取第一个工作表
    
            # 获取所有 合并单元格的 位置信息
            # 是个可迭代对象,单个对象类型:openpyxl.worksheet.cell_range.CellRange
            # print后就是excel坐标信息
            m_list = worksheet.merged_cells
    
            l = deepcopy(m_list)# 深拷贝
    
            # 拆分合并的单元格 并填充内容
            for m_area in l:
                
                # 这里的行和列的起始值(索引),和Excel的一样,从1开始,并不是从0开始(注意)
                r1, r2, c1, c2 = m_area.min_row, m_area.max_row, m_area.min_col, m_area.max_col
                    
                worksheet.unmerge_cells(start_row=r1, end_row=r2, start_column=c1, end_column=c2)
                #print('区域:', m_area, '  坐标:', r1, r2, c1, c2)
                
                # 获取一个单元格的内容
                first_value = worksheet.cell(r1, c1).value
    
                # 数据填充
                for r in range(r1, r2+1):# 遍历行        
                    if c2 - c1 > 0:# 多个列,遍历列
                        for c in range(c1, c2+1):
                            worksheet.cell(r, c).value = first_value
                    else:# 一个列
                        worksheet.cell(r, c1).value = first_value
    
    
            # 删除行
            worksheet.delete_rows(2)
            worksheet.delete_rows(1)
    
            
            worksheet2 = workbook2.create_sheet(name_list[index])
            for x in range(worksheet.max_row):# 首列批量填充数据
                r = x+1
                for y in range(worksheet.max_column):
                    c = y+1
                    worksheet2.cell(r, c).value = worksheet.cell(r, c).value
            
    
            # 列宽度自适应
            for y in range(worksheet.max_column):
                column_width = 10
                for x in range(worksheet.max_row):
                    c = y+1
                    r = x+1
                    cellLength = 10
                    cellValue = worksheet.cell(r, c).value
                    if cellValue is not None:
                        if type(cellValue) == int:
                            cellLength = 10
                        else:
                            cellLength = len(cellValue)
                    if cellLength > column_
                        column_width = cellLength
                column_NameEn = get_column_letter(y + 1)
                worksheet2.column_dimensions[column_NameEn].width = column_width * 2
    
    
    
    
    def each_files():    
        pathDir =  os.listdir('./files/')
        for index, value in enumerate(pathDir):
            filepath2 = './files/' + value
            print(filepath2)
            create_worksheet(filepath2)
            
    
    
    each_files()
    workbook2.save('test2.xlsx')
    
    

    数据导入后 用到的sql

    主要是为了去掉 合同段那一级

    -- delete from Projects
    
    select * from Projects order by Id asc
    
    UPDATE [Projects] SET ProjectCode=SUBSTRING(ProjectCode,4 ,LEN(ProjectCode)-4+1) WHERE Id>510322
    
    UPDATE [Projects] SET [LEVEL]=[Level]-1 WHERE Id>510322
    
    delete from Projects WHERE Id=510322
    
    update Projects set ParentId=510321 where ParentId=510322
    

    效果

  • 相关阅读:
    DS博客作业02--栈和队列
    DS博客作业03--树
    C博客作业05--指针
    C语言博客作业04--数组
    C博客作业03--函数
    C博客作业02--循环结构
    C博客作业01--分支、顺序结构
    我的第一篇博客作业
    java购物车案例
    第三周-自主学习任务-面向对象基础与类的识别
  • 原文地址:https://www.cnblogs.com/guxingy/p/15688203.html
Copyright © 2011-2022 走看看