派森 #P134. 销售数据统计

描述

在sale.in文件存储了员工一年中每个月的销售数据(csv格式,utf-8编码),请读取该文件,并计算每位员工的年销售综合,再按年度销售综合降序排序后写到sale.out文件(csv格式,utf-8编码)。

格式

输入:sale.in文件

工号,1月,2月,3月,4月,5月,6月,7月,8月,9月,10月,11月,12月
5101,12880,9134,5299,5521,17611,7410,6578,7585,17145,7392,16280,19808
5102,6795,11227,9310,17819,16288,7093,7326,12608,15649,11195,9342,14097
5103,11778,19734,5221,19926,5515,14114,7282,15044,15851,18634,18191,6560
5104,16643,12989,6242,19867,18364,19012,12072,16292,5455,8927,15801,7097
5105,12243,10570,18985,7691,12688,17099,7395,14730,7682,12708,14190,6015
5106,14927,12658,5869,7990,17165,11031,5579,5403,17807,19776,19185,9732
5107,10373,6889,12498,10839,18681,15702,10454,8959,5946,12795,6391,14205
5108,18076,5237,16988,10745,8217,11326,17288,12679,8133,5003,11962,14843
5109,11936,5857,13456,7165,11734,16119,18231,11949,15966,14399,11281,19659
5110,5007,19474,11562,19441,17379,12101,19592,7374,11097,8847,9256,9122

输出:sale.out文件

工号,1月,2月,3月,4月,5月,6月,7月,8月,9月,10月,11月,12月,年度总销售量
5104,16643,12989,6242,19867,18364,19012,12072,16292,5455,8927,15801,7097,158761
5103,11778,19734,5221,19926,5515,14114,7282,15044,15851,18634,18191,6560,157850
5109,11936,5857,13456,7165,11734,16119,18231,11949,15966,14399,11281,19659,157752
5110,5007,19474,11562,19441,17379,12101,19592,7374,11097,8847,9256,9122,150252
5106,14927,12658,5869,7990,17165,11031,5579,5403,17807,19776,19185,9732,147122
5105,12243,10570,18985,7691,12688,17099,7395,14730,7682,12708,14190,6015,141996
5108,18076,5237,16988,10745,8217,11326,17288,12679,8133,5003,11962,14843,140497
5102,6795,11227,9310,17819,16288,7093,7326,12608,15649,11195,9342,14097,138749
5107,10373,6889,12498,10839,18681,15702,10454,8959,5946,12795,6391,14205,133732
5101,12880,9134,5299,5521,17611,7410,6578,7585,17145,7

代码:

fr = open('sale.in', 'r', encoding='utf-8')
fw = open('sale.out', 'w', encoding='utf-8')
lst = []
for line in fr:
    line = line.replace('\n', '')
    lst.append(line.split(','))
fr.close()
lst[0].append("年度总销售量")
for i in range(1, len(lst)):
    total_income = 0
    for j in range(1, len(lst[i])):
        total_income += int(lst[i][j])
    lst[i].append(str(total_income))
lst[1:] = sorted(lst[1:], key=lambda x: int(x[-1]), reverse=True)
for item in lst:
    fw.write(','.join(item) + '\n')
fw.close()

代码解析:

  1. fr = open('sale.in', 'r', encoding='utf-8'):打开名为'sale.in'的文件,以只读模式读取(默认模式为文本模式),并指定编码为UTF-8。将文件对象赋值给变量fr
  2. fw = open('sale.out', 'w', encoding='utf-8'):打开名为'sale.out'的文件,以写入模式写入(默认模式为文本模式),并指定编码为UTF-8。将文件对象赋值给变量fw
  3. lst = []:创建一个空列表lst,用于存储从文件中读取的数据。
  4. for line in fr::遍历文件对象fr中的每一行数据,每次将一行赋值给变量line
  5. line = line.replace('\n', ''):将变量line中的换行符替换为空字符串,去除字符串末尾的换行符。
  6. lst.append(line.split(',')):将使用逗号对变量line进行分割后的结果作为列表添加到lst列表中,实现将每行数据拆分成列表的效果。
  7. fr.close():关闭文件对象fr,释放资源。
  8. lst[0].append("年度总销售量"):在lst列表的第一个子列表(即表头)中添加字符串"年度总销售量",作为新的列名。
  9. for i in range(1, len(lst))::遍历从索引1到lst列表的长度之间的整数,每次将一个整数赋值给变量i
  10. total_income = 0:创建一个变量total_income并初始化为0,用于存储总销售量。
  11. for j in range(1, len(lst[i]))::遍历从索引1到lst[i]子列表的长度之间的整数,每次将一个整数赋值给变量j
  12. total_income += int(lst[i][j]):将lst[i][j]中的值解析为整数,累加到total_income变量中,计算总销售量。
  13. lst[i].append(str(total_income)):将总销售量转换为字符串,并添加到lst[i]子列表的末尾,作为新的列数据。
  14. lst[1:] = sorted(lst[1:], key=lambda x: int(x[-1]), reverse=True):对lst列表中从索引1开始的子列表进行排序,排序依据为子列表的最后一个元素(即总销售量),使用降序排序。重新赋值给lst[1:],实现根据总销售量对数据进行排序。
  15. for item in lst::遍历lst列表中的每个元素,每次将一个子列表赋值给变量item
  16. fw.write(','.join(item) + '\n'):将item子列表中的元素使用逗号连接成一个字符串,并写入文件对象fw中,末尾添加换行符。
  17. fw.close():关闭文件对象fw,释放资源。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的微信机器人框架的代码示例,你可以根据需要进行修改和优化: ```python import itchat from threading import Thread from queue import Queue class WechatBot: def __init__(self): self.msg_queue = Queue() self.bot = itchat.new_instance() self.bot.auto_login(hotReload=True) self.bot.run(blockThread=False) self.friend_list = self.bot.get_friends() def send_msg(self, msg, to_user): self.bot.send(msg, toUserName=to_user) def handle_msg(self, msg): from_user = msg['FromUserName'] msg_type = msg['Type'] if msg_type == 'Text': content = msg['Text'] self.msg_queue.put((from_user, content)) def listen(self): @self.bot.msg_register(['Text', 'Picture', 'Recording', 'Attachment', 'Video']) def receive_msg(msg): self.handle_msg(msg) def run(self): listen_thread = Thread(target=self.listen) listen_thread.start() while True: if not self.msg_queue.empty(): from_user, content = self.msg_queue.get() # 处理消息并回复 reply = self.reply(content, from_user) self.send_msg(reply, from_user) def reply(self, msg, from_user): # 实现具体的自动回复逻辑 return "这是机器人自动回复的消息。" if __name__ == '__main__': bot = WechatBot() bot.run() ``` 以上代码实现了一个基本的微信机器人框架,它能够监听用户发送的消息并将其加入消息队列,然后在主线程中不断从消息队列中读取消息并进行处理和回复。你可以根据需要修改 `reply` 函数来实现具体的自动回复逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值