首页 > 编程语言 >Python 分部分项 数据处理2 桂柳

Python 分部分项 数据处理2 桂柳

时间:2022-09-26 16:47:59浏览次数:53  
标签:Python worksheet value cell column range 桂柳 数据处理 c1

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, 0, -1):
            c = y
            r = 1
            cellValue = worksheet.cell(r, c).value
            if cellValue is not None:
                if "编号" in cellValue:
                    worksheet2.delete_cols(y)


        # 列宽度自适应
        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_width:
                    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')


标签:Python,worksheet,value,cell,column,range,桂柳,数据处理,c1
From: https://www.cnblogs.com/guxingy/p/16731433.html

相关文章

  • 【Python】【Flask】【字符串索引】计算人民币与美元的相互计算
    目录简介PythonCode导包设置首页计算的接口问题0:设置请求方式问题1:关于接收数据可能存在的问题问题2:返回结果启动完整代码HTMLCode问题分析分析:获取下拉列表框的选中值分......
  • python-模块-模块导入之其它函数
    1.dir()dir()函数一个排好序的字符串列表,内容是一个模块里定义过的名字。返回的列表容纳了在一个模块里定义的所有模块,变量和函数1.1dir示例定义一个模块#coding-......
  • python中实现days360函数
    #-*-coding:utf-8-*-"""CreatedonFriSep2320:42:582022@author:Administrator"""importtimeimportdatetimedefdays360(start_date,end_date,meth......
  • python入门第四课--数据类型、格式化输出、基本符号的意义
    今日内容概要作业讲解python基本数据类型与用户交互格式化输出基本运算符多种赋值方式逻辑运算符成员运算符身份运算符流程控制理论今日内容详细作业讲......
  • 【转载】Python -- 多进程、多线程 的基本使用
    https://www.cnblogs.com/jiyu-hlzy/p/15948408.html 单进程单线程importtimedefproduction():"""间隔一秒,模拟一秒生产一个任务,生产10个任务:ret......
  • Python菱形继承(网易面试题)
    菱形继承顾名思义,是一个菱形继承(好像是废话),直接上图  菱形继承就是多继承,例上图所有,A是父类,B和C是A的子类,B和C是D的父类。classParent(object):def__init__(......
  • Python Web Django
    全文:https://www.cnblogs.com/MrFlySand/p/16730898.html1.6创建Django项目进入cmd窗口,输入如下命令,创建Django项目django-adminstartprojectDjango,如下是在code文......
  • python显示图片
    python读取并显示图片的两种方法-邊城浪子-博客园(cnblogs.com)python读取并显示图片的两种方法在python中除了用opencv,也可以用matplotlib和PIL这两个......
  • 面向机器学习工程师的 Python 设计模式:Observer
    Photoby杰森梁on不飞溅面向机器学习工程师的Python设计模式:Observer了解如何通过采用设计模式来构建代码:基于Instagram的示例介绍模式描述了一个经常出现的......
  • python各个模块的作用
    一.OS模块:整理文件和目录os.popen()函数与cmd命令窗口之间建立一个双向通道,可以从cmd窗口和程序间相互读取信息  二。time 等待,获取时间为python的内置模块在Pyt......