Python_Excel文件操作

时间:2023-01-15 21:16:11
 '''
使用xlrd模块写入Excel文件
'''
import xlrd
book=xlrd.open_workbook(r'/Users/c2apple/Desktop/纪录/测试报告/张涛文件盘/骆洪文模版/彩屏带杨升/ZD-QR-730114 彩屏软件测试报告 00版.xlsx')#打开Excel文件
sheet1=book.sheet_by_name('First') #打开worksheet
row0=sheet1.row(0) #获取第0行
print(row0[0])
print(row0[0].value) #查看单元格中的内容 #使用扩展库openpyxl读取Excel2007及更高版本的Excel文件
import openpyxl
from openpyxl import Workbook
fn=r'/Users/c2apple/Desktop/test.xlsx' #文件名
wb=Workbook() #创建工作簿
ws=wb.create_sheet(title='你好,世界') #单元格赋值
ws['A1']='这是第一个单元格' #单元格赋值
ws['B1']=3.1415926
wb.save(fn) #保存Excel文件
wb=openpyxl.load_workbook(fn) #打开已有的Excel文件
ws=wb.worksheets[1] #打开指定索引的工作表
print(ws['A1'].value) #读取并输出指定单元格的值
ws.append([1,2,3,4,5]) #添加一行数据
ws.merge_cells('F2:F3') #合并单元格
ws['F2']="=sum(A2:E2)" #写入公式
for r in range(10,15):
for c in range(3,8):
_=ws.cell(row=r,column=c,value=r*c) #写入单元格数据
wb.save(fn) '''
假设某学校所有课程每学期允许多次考试,学生可随时参加考试,系统自动将每次成绩
添加到Excel文件(包含3列,姓名、课程、成绩)中,现期末要求统计所有学生每门课程的最高成绩。
下面代码首先模拟生成随机成绩数据,然后进行统计分析.
'''
import openpyxl
from openpyxl import Workbook
import random #随机生成数据
def generatetRandomInformation(filename):
workbook=Workbook()
worksheett=workbook.worksheets[0]
worksheett.append(['姓名','课程','成绩'])
#中文名字中的第一、第二、第三个字
first=tuple('赵钱孙李')
middle=tuple('伟昀琛东')
last=tuple('坤艳志')
#课程名称
subject=('语文','数学','英语')
#随机生成200个数据
for i in range(200):
line=[]
r=random.randint(1,100)
name=random.choice(first)
#按一定概率生成只有两个字的中文名字
if i>50:
name=name+random.choice(middle)
name=name+random.choice(last)
#依次生成姓名、课程名、和成绩
line.append(name)
line.append(random.choice(subject))
line.append(random.randint(0,100))
worksheett.append(line)
#保存数九,生成Excel 2007格式的文件
workbook.save(filename) def getResult(oldfile, newfile):
#用于存放结果数据的字典
result = dict() #打开原始数据
workbook = openpyxl.load_workbook(oldfile)
worksheet = workbook.worksheets[0] #遍历原始数据
for row in worksheet.rows:
if row[0].value == '姓名':
continue
#姓名,课程名称,本次成绩
name, subject, grade = row[0].value, row[1].value, row[2].value #获取当前姓名对应的课程名称和成绩信息
#如果result字典中不包含,则返回空字典
t = result.get(name, {})
#获取当前学生当前课程的成绩,若不存在,返回0
f = t.get(subject, 0)
#只保留该学生该课程的最高成绩
if grade > f:
t[subject] = grade
result[name] = t workbook1 = Workbook()
worksheet1 = workbook1.worksheets[0]
worksheet1.append(['姓名','课程','成绩']) #将result字典中的结果数据写入Excel文件
for name, t in result.items():
print(name,t)
for subject, grade in t.items():
worksheet1.append([name, subject, grade]) workbook1.save(newfile) if __name__=='__main__':
oldfile=r'test1.xlsx'
newfile=r'resultt.xlsx'
generatetRandomInformation(oldfile)
getResult(oldfile,newfile)