综合应用题:python文件(论语)

十二星座日期范围之一

在这里插入图片描述

fo = open("PY301-SunSign.csv","r",encoding='utf-8')
ls = []
for line in fo.readlines():
    line = line.replace("\n","")
    ls.append(line.split(","))
s = input("请输入星座中文名称(例如, 双子座):")
for i in range(len(ls)):
    if s == ls[i][1]:
        print("{}的生日位于{}-{}之间".format(s,ls[i][2],ls[i][3]))

《论语》

在这里插入图片描述

fi = open("D:\文件下载\论语.txt", "r",encoding='utf-8')
fo = open("D:\文件下载\论语-原文.txt", "w",encoding='utf-8')
a=0
for line in fi:
    if a==1 and line.count("【注释】")==0 and line.count("【原文】")==0:
        line = line.strip(" \n")
        if line.strip():#判断line是否为空串
            fo.write('{}\n'.format(line))
    if line.count("【原文】")>0:
        a=1
    if line.count("【注释】")>0:
        a=0
fi.close()
fo.close()

问题1:从网络下载的"论语.txt"中粗略提取原文,形成"论语-原文.txt"。读写文件分别采用open()函数的"r"和"w"模式。
问题1提取【原文】后面区域的内容,与单行提取不同,区域提取文本需要处理若干行,为此,需建立一个标记即a参数。
当遇到"【原文】"字样时,将a标记为1,后续读入该区域其他行时,按照【原文】对应区域块的文本进行处理。当遇到【注释】标记时,则将a标记为0,表示程序已离开了【原文】区域。根据a变量值,确定是否将文本内容输出到新的文件中。

在这里插入图片描述

fi = open("D:\文件下载\论语-原文.txt",'r',encoding='utf-8')
fo = open("D:\文件下载\论语-提纯原文.txt",'w',encoding='utf-8')
for line in fi:
    for k in range(100):
        line=line.replace('(' + str(k) + ')', '')
    fo.write(line)
fi.close()
fo.close()

问题2:在问题1的基础上,进一步对提取后原文内容进行清理,去掉其中出现的小括号及内部数字,例如(1)、(2)等。简单的思路是逐一替换上述出现的字符串为空字符串,这种替换相当于删除上述字符串,可采用.replace()函数进行。

计算总成绩

在这里插入图片描述

#使用with语句打开文件,处理结束后,不需要使用close()语句关闭文件
with open("data.txt","r",encoding="utf-8") as fi:  
    for line in fi.readlines():         #遍历每一行,例如line内容为:"李启睿,110,115,119\n"
        line = line.split(",")          #用","分割,例如line由字符串变成了列表:["李启睿","110","115","119"]
        print(eval(line[1])+eval(line[2])+eval(line[3])) #输出110+115+119表达式的结果

MOOC学校名单

在这里插入图片描述

#解析中国大学MOOC网页中的alt="南京理工大学"及数据统计
fi = open(r"D:\文件下载\data.txt","r", encoding='utf-8')   #以只读方式打开data.txt文件
f = open(r"D:\文件下载\univ.txt","w", encoding='utf-8')    #以写的方式打开univ.txt文件(新生成文件univ.txt)
for line in fi:             #对data.txt文件中每一行进行处理
    if "alt" in line:       #如果行字符中包含"alt"字符串,
                            #例如:line = "<img class="" id="" src="%E5%A4%A7%E5%AD%A6%E5%88%97%E8%A1%A8_%E4%B8%\
                            #      AD%E5%9B%BD%E5%A4%A7%E5%AD%A6MOOC(%E6%85%95%E8%AF%BE)_files/370D4ADD98FE6993DE1970DB0060ACCA.png" \
                            #      alt="北京大学" width="164" height="60">"
        # print(line)
        dx = line.split("alt=")[-1].split('"')[1]
        # print(line.split("alt=")[-1])  #得到字符串:"北京大学" width="164" height="60">
        # print(line.split("alt=")[-1].split('"')) #得到列表:['', '北京大学', ' width=', '164', ' height=', '60', '>\n']
        # print(line.split("alt=")[-1].split('"')[1]) #得到字符串:北京大学
        # break 只分析第一个包含alt=的line
        f.write("{}\n".format(dx))  #逐行写提取的字符到文件univ.txt中
f.close()   #关闭文件
fi.close()  #关闭文件

解码错误的三种解决方法

n = 0    #记录大学数量的计数器n
m = 0    #记录学院数量的计数器m
f = open(r"D:\文件下载\univ.txt", "r",encoding='utf-8')  #以读的方式打开文件univ.txt
lines = f.readlines()      #返回一个列表,列表中每一个元素对于文件中每一行
f.close()
for line in lines:      #遍历列表中每一个元素
    line = line.replace("\n","")   #去除元素中的换行符
    if '大学生' in line:           #如果列表元素中包含"大学生"字符串,不做计数
        continue
    elif '学院' in line and '大学' in line:  #形如中国科学院大学、南京理工大学紫金学院的计数处理
        if line[-2:] == '学院':              #例如:南京大学金陵学院,归属于学院,不归属于大学;
            m += 1
        elif line[-2:] == '大学':            #例如:中国科学院大学,不归属于学院,归属于大学;
            n += 1
        print('{}'.format(line))
    elif '学院' in line:           #如果列表元素中包含"学院"字符串,则默认计数为学院+1
        print('{}'.format(line))                                      #例如:江苏理工学院,归属于学院
        m += 1
    elif '大学' in line:           #基于列表元素中不包含"学院"字符串,而包含"大学"字符串
        print('{}'.format(line))   #计数为大学+1,例如南京大学
        n += 1
print("包含大学的名称数量是{}".format(n)) #输出大学计数
print("包含学院的名称数量是{}".format(m)) #输出学院计数

血压值分析输出

在这里插入图片描述

jl = [[],[],[],[],[]]   # 定义空的二维列表jl,例如:
                           #jl[1]用于存放左臂高压值:[104,154,131,...]
                           #jl[2]用于存放左臂低压值:[82,88,82,...]
                           #jl[3]用于存放右臂高压值:[136,155,139,...]
                           #jl[4]用于存放右臂低压值:[90,85,74,...]

zyc = [] #存放左臂压差值列表[22,66,...]
yyc = [] #存放右臂压差值列表[46,60,...]

#用with语句打开xueyajilu.txt文件
with open(r"D:\文件下载\xueyajilu.txt", 'r',encoding='utf-8') as fi:
    for l in fi:  #对文件中的每一行内容进行处理
        if len(l):            #过滤空行
            lls = l.split(',')
            #print(l.split(','))
            #例如第一行的lls:['2018/7/2 6:00', '140', '82', '136', '90']
            #注意第一列是时间,不需要,跳过            
            for i in range(1,5):     #i从1开始,就是为了跳过第一列时间
                jl[i].append(eval(lls[i])) #构建二维列表jl,从文件里读取的都是字符串,所有需要eval转换成整数
            zyc.append(eval(lls[1])- eval(lls[2]))  #左臂压差:左臂高压值 - 左臂低压值
            yyc.append(eval(lls[3])- eval(lls[4]))  #右臂压差:右臂高压值 - 右臂低压值

cnt = len(zyc)   #记录条数

res = []   #构建对比表
res.append(list(("高压最大值",max(jl[1]),max(jl[3]))))
#"高压最大值"、左臂高压最大值和右臂高压最大值构建列表增加到res[0]
res.append(list(("低压最大值",max(jl[2]),max(jl[4]))))
#"低压最大值"、左臂低压最大值和右臂低压最大值构建列表增加到res[1]
res.append(list(("压差平均值",sum(zyc)//cnt,sum(yyc)//cnt)))
#"压差平均值"、左臂高低压差平均值和右臂高低压差平均值构建列表增加到res[2]   //:取整除 - 返回商的整数部分(向下取整)
res.append(list(("高压平均值",sum(jl[1])//cnt,sum(jl[3])//cnt)))
#"高压平均值"、左臂高压平均值和右臂高压平均值构建列表增加到res[3]           //:取整除 - 返回商的整数部分(向下取整)
res.append(list(("低压平均值",sum(jl[2])//cnt,sum(jl[4])//cnt)))
#"低压平均值"、左臂低压平均值和右臂低压平均值构建列表增加到res[4]           //:取整除 - 返回商的整数部分(向下取整)

print('{0:<10}{1:<10}{2:<10}'.format("对比项", "左臂", "右臂"))  #输出标题行
for r in range(len(res)):
    print('{0:<10}{1:<10}{2:<10}'.format(res[r][0],res[r][1],res[r][2]))
    #输出左右臂的高压最大值、低压最大值、压差平均值、高压平均值、低压平均值

通讯录管理

在这里插入图片描述

#P301-1
menu=["1. 显示所有信息","2. 追加信息","3. 删除信息"]
flag = 1
while flag:
   for m in menu:
       print(m)
   try:
       print("请输入数字1-3选择功能:")
       ch = int(input() )
       flag =0
   except:
       flag = 1
   if    ch <1 or ch > 3:
       flag = 1

print("您选择了功能", ch)

#P301-2

def display():
   fi = open("address.txt",'r')
   for l in fi:
       l=l.replace('\n','')
       print(l)
   fi.close()
        
menu=["1. 显示所有信息","2. 追加信息","3. 删除信息"]
flag = 1
while flag:
   for m in menu:
       print(m)
   try:
       print("请输入数字1-3选择功能:")
       ch = int(input() )
       flag =0
   except:
       flag = 1
   if    ch <1 or ch > 3:
       flag = 1

if ch ==1:
   display()
elif ch==2:
   pass
elif ch ==3:
   pass

# P301-3
def display():
   fi = open("address.txt",'r')
   for l in fi:
       l=l.replace('\n','')
       print(l)
   fi.close()        

def insertrec():
   fi = open("address.txt",'r')
   fo = open("new_address.txt",'w')
   la=[]
   for l in fi:
       la.append(l.replace('\n',''))
   print("请输入要插入的信息,以逗号隔开,示例:103, cc, 34567812, tianjing:")
   rec = input()
   la.append(rec)
   for l in la:
       fo.write(l)
       fo.write('\n')
   fi.close()
   fo.close()

menu=["1. 显示所有信息","2. 追加信息","3. 删除信息"]
flag = 1
while flag:
   for m in menu:
       print(m)
   try:
       print("请输入数字1-3选择功能:")
       ch = int(input() )
       flag =0
   except:
       flag = 1
   if    ch <1 or ch > 3:
       flag = 1

if ch ==1:
   display()
elif ch==2:
   insertrec()
elif ch ==3:
   pass
#   

人脸识别数据测试

在这里插入图片描述

picd = {}
fi = open("dir_50.txt",'r')
for l in fi:
    l = l.strip()
    if len(l):
        l=l.split('_')
        lkey,lvalue = l[1][:-4],eval(l[0])
        lval = []
        for v in lvalue:
            if v != '0':
                lval.append(v)
        # print(lval, lkey)
        picd[lkey] = lval

fi.close()
idd = {}
for key in picd:
    for num in picd[key]:
        idd[num] = idd.get(num,0) +1
    # print(num,idd[num])

s = sum(idd.values())
count = len(idd)
print("实际参加测试的人数是:{}".format(count))
print("人均被测次数是:{:.1f}".format(s/count))

写入字符串

在这里插入图片描述

fp = open("out.txt","w")                #以写的方式打开文件out.txt
ch = input("请输入字符串:\n")         #请输入待写入文件的内容,例如python123.io@
while ch != '@':                       #使用无限循环的方式,重复检查输入内容中是否存在"@"
    if '@' in ch:                      #如果ch中存在"@",则截取"@"之前的字符,写入文件。
        t = ch.find("@")               #find函数是字符串查找函数
        fp.write(ch[0:t])              #截取"@"之前的字符,写入文件。
        break                          #终止无限循环
                                       #(这是无限循环的终止条件,如果没有获得一个"@"输入,按回车后,会一直要求输入。)
    else:
        fp.write(ch + " ")             #将按回车前的输入,用一个英文空格隔开,写入文件中
    ch = input("")                     #继续从键盘获得输入,赋值给ch
fp.close()                             #关闭文件。


'''某种执行过程如下:
请输入字符串:
Python
is 
open.@Python123

执行后,out.txt文件内容为:Python is open.
'''

文件数据读取计算

在这里插入图片描述

fi = open("data.txt", 'r')
for l in fi:
    l = l.split(',')
    s = 0.0
    n = len(l)
    for cours in l:
        items  = cours.split(':')
        s += eval(items[1])
    print("总和是:{},平均值是:{:.2f}".format(s,s/n))
fi.close()

奖学金评选条件

在这里插入图片描述

f = open("score.txt","r")
D = [] #单个学生的数据
L = [] #所有学生原始成绩和总成绩
#读取学生单科成绩并计算总成绩
for line in f.readlines():
    D = line.split()
    s = 0 #每个学生的总成绩初始值
    for i in range(10):
        s += int(D[i+2]) #各科成绩累加求和,+2是因为前两个元素是学号和姓名
    D.append(s)
    L.append(D)
f.close()
L.sort(key=lambda x:x[-1],reverse=True) #按学生总成绩从大到小排序

f = open('candidate0.txt','w')
for i in range(10): #取前十个学生数据
    for j in range(len(L[i])): #一个学生的各项数据
        f.write('{} '.format(L[i][j])) #文件中写入各项数据,用空格隔开
    f.write('\n') #换行
f.close()
#P301-2
f = open("candidate0.txt",'r')
lines = f.readlines()
f.close()
D = []
f = open('candidate.txt','w')
for line in lines:
    D = line.split()
    for i in range(10):
        if int (D[i+2]) < 60:
            break
    else:
        f.write('{}{}\n'.format(D[0],D[1]))
f.close() 
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值