Python如何实现改正excel数据,现实过程是怎样
Admin 2022-08-13 群英技术资讯 924 次浏览
这篇文章主要介绍了Python如何实现改正excel数据,现实过程是怎样相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python如何实现改正excel数据,现实过程是怎样文章都会有所收获,下面我们一起来看看吧。先上客户的需求:

主要用到的模块为openpyxl、random
import openpyxl import random from openpyxl.utils.cell import get_column_letter,column_index_from_string
除了运用到openpyxl和random还用到了openpyxl中的utils包下cell模块的两个方法,第一个方法get_column_letter的作用是将整型转换为对应excel中列属性的字符串,例如:12转换为L,50转换为AX
第二个方法是将字符串转换为整型,其本质类似于10进制和27进制之间的转换,当然你也可以自己写,下面附上自己写的行(整型)转换为列(字符串)的代码。
def num_to_string(n): column = n - 1 real_colum = '' while column >= 26: value = column // 26 column = column % 26 real_colum += chr(value + 64) real_colum += chr(column + 65) return real_colum
#创建一个全局变量MATERIAL_MESSAGE
MATERIAL_MESSAGE = []
#获取小宛中数据
def get_construct_message():
#读取数据原表.xlsx表
wb = openpyxl.load_workbook('数据原表.xlsx')
#获取获取当前活动工作表,默认为第一个表
ws = wb.active
#获取在生产记录更新.xlsx中的可以用到的数据存入MATERIAL_MESSAGE中
for row in range(1,ws.max_row + 1):
if ws[f'A{row}'].value == '日期':
for i in range(ord('B'),ord('I')):
material = []
#将日期转换为与生产记录更新中相对应写法的形式
date = ws[f'B{row}'].value.translate(str.maketrans('年月','--'))
date = date.replace('号','')
material.append(date)
i = chr(i)
material.append(ws[f'{i}{row + 1}'].value)
material.append(ws[f'{i}{row + 3}'].value)
MATERIAL_MESSAGE.append(material)
print(MATERIAL_MESSAGE)
# 将客户要求的对应数据存入字典中
TABLES = {"水泥":"水泥1","粉煤灰":"煤灰","河沙":"沙1","粗骨料1":"石1","粗骨料2":"石2","减水剂":"外加剂","水":"水"}
#存入生产记录更新表的日期和其所在的行数
DATE = []
#存入生产记录更新表的材料和其所在的列数
MATERIAL = []
wb = openpyxl.load_workbook('生产记录更新.xlsx')
ws = wb.active
#获取日期
def get_date():
for row in range(3,ws.max_row + 1):
#将日期进行分割合并转换成与MATERIAL_MESSAGE中对应日期的格式
date = str(ws[f'B{row}'].value).split()[0]
date_list = date.split('-')
if '0' in date_list[1]:
date_list[1] = date_list[1].replace('0','')
if '0' in date_list[2]:
date_list[2] = date_list[2].replace('0','')
date = '-'.join(date_list)
DATE.append([date,row])
pprint.pprint(DATE)
#获取材料
def get_material():
n = 0
for column in ws[1]:
n += 1
#判断该单元格的内容是否在TABLES中
if column.value in TABLES.values():
#运用行列转换的方法进行转换
MATERIAL.append([column.value,get_column_letter(n - 1)])
pprint.pprint(MATERIAL)
DATE表部分数据:

MATERIAL表数据:

#两个参数分别为材料的类型和所在的列数
def update_default(matrial,letter):
for row in range(3,ws.max_row + 1):
#判断单元格是否为空
if ws[f'{letter}{row}'].value != None:
for i in range(len(MATERIAL_MESSAGE)):
#需求条件,要将连个表中的日期和材料类型进行一一对应
if DATE[row-3][0] == MATERIAL_MESSAGE[i][0] and matrial == TABLES[MATERIAL_MESSAGE[i][1]]:
#修改形参letter对应列的每个符号要求的单元格对应的设定值
ws[f'{letter}{DATE[row - 3][1]}'].value = MATERIAL_MESSAGE[i][2]
#分别获取该列列号的下两列对应的列号
letter_random = get_column_letter(column_index_from_string(letter) + 2)
letter_real = get_column_letter(column_index_from_string(letter) + 1)
#判断该列是否在这三列中,若在其中则得到-2到2之间的随机数,否则-1到1之间的随机数,并更新误差值
if letter in ('AV','BB','BE'):
ws[f'{letter_random}{DATE[row - 3][1]}'].value = round(random.uniform(-2, 2), 1)
else:
ws[f'{letter_random}{DATE[row - 3][1]}'].value = round(random.uniform(-1, 1), 1)
#运用设定值和误差值更新中间的实际值
ws[f'{letter_real}{DATE[row - 3][1]}'].value = round(ws[f'{letter}{DATE[row - 3][1]}'].value * (1 + ws[f'{letter_random}{DATE[row - 3][1]}'].value * 0.01),2)
def main():
get_construct_message()
get_date()
get_material()
for i in MATERIAL:
update_default(i[0],i[1])
wb.save('生产记录更新.xlsx')
if __name__ == "__main__":
main()
修改前部分数据:

修改后部分数据:

总的来说,难度不在于怎么修改数据,而是在于怎么把两个表相互关联,通过这次接单让我对excel表能够更加熟练地进行操作,接单既能提升自己的能力,又能赚点外快,何乐而不为呢?
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
1.abs()函数返回数字的绝对值。print(abs(-45))#返回45print("abs(0.2):",abs(0.2))#返回abs(0.2):0.2 2. all()函数用于判断给定的参数中的所有元素是否都为TRUE,如果是返回True,否则返回False。元素除了是0、空、None、False
这篇文章给大家分享的是有关Python中Numpy怎么用的内容。Numpy是Python学习的基础内容,小编觉得挺实用的,因此分享给大家做个参考,接下来一起跟随小编看看吧。
玫瑰花图是节理统计方式之一,方法简便,形象醒目,比较清楚地反映出主要节理的方向,有助于分析区域构造。本文将用Python绘制好看的玫瑰花图,感兴趣的可以了解一下
这篇文章主要介绍了Python中的PyInputPlus模块详解,PyInputPlus包含与input()类似的、用户多种数据(数字日期、E-mail地址等)的函数,PyInputPlus还包含其他有用的功能,本文给大家介绍的非常详细,需要的朋友可以参考下
在Python3中正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008