1、在命令行环境中使用pip install openpyxl命令安装扩展库openpyxl。 2、使用随机数函数生成学生成绩数据,并写入自行指定的学生初始成绩表中。 3、统计学生的最高成绩,并写入自行指定的学生最终成绩表中
时间: 2024-03-05 13:53:37 浏览: 63
好的,以下是代码实现:
```python
import openpyxl
import random
# 打开初始成绩表
wb = openpyxl.load_workbook('initial_scores.xlsx')
ws = wb.active
# 生成学生成绩数据,并写入初始成绩表中
for row in ws.iter_rows(min_row=2):
for cell in row[1:]:
# 生成0~100之间的随机整数作为学生成绩
score = random.randint(0, 100)
cell.value = score
# 统计学生的最高成绩,并写入最终成绩表中
wb2 = openpyxl.Workbook()
ws2 = wb2.active
ws2.title = 'final_scores'
ws2['A1'] = '学生姓名'
ws2['B1'] = '最高成绩'
for row in ws.iter_rows(min_row=2):
name = row[0].value
max_score = max([cell.value for cell in row[1:]])
ws2.append([name, max_score])
# 保存最终成绩表
wb2.save('final_scores.xlsx')
```
这段代码的作用是:
1. 打开一个名为initial_scores.xlsx的Excel文件,里面有学生姓名和成绩两列。
2. 循环遍历初始成绩表中每个学生的成绩单元格,使用random模块中的randint函数生成0~100之间的随机整数,并将其写入单元格中。
3. 创建一个新的Excel文件,命名为final_scores.xlsx,并在其中创建一个名为final_scores的工作表。
4. 在final_scores工作表中,创建两个列,分别为“学生姓名”和“最高成绩”。
5. 循环遍历初始成绩表中每个学生的成绩,找到每个学生的最高成绩,并将其写入final_scores工作表中的对应行。
6. 保存final_scores.xlsx文件。
阅读全文