python 文件作业(题3) 不要老是忽略考虑指针位置,已经错了2次了

def count(t):
    u=l=d=s=others=0
    for i in t:
        if i.isupper():
            u+=1
        elif i.islower():
            l+=1
        elif i.isnumeric():
            d+=1
        elif i.isspace():
            s+=1
        else:
            others+=1
    print(u,l,d,s,others) 


def word(fr):
    sum=0
    for line in fr:
        for j in '.'+','+"'":
            line=line.replace(j,'') 
        ls=line.split(" ")
        sum+=len(ls)
    return sum
def shiftkey(x):
    sum=0
    for j in x:
        sum+=ord(j)
    return sum 

def shift(t,r):
    s=''
    for i in t:
        if i.isupper():
            i=chr(ord('A')+(ord(i)-ord('A')+r)%26)
        elif i.islower():
            i=chr(ord('a')+(ord(i)-ord('a')+r)%26)
        s+=i
    return s

key=shiftkey(input())%26
fr=open("mayun.txt","r")
t=fr.read()#这读完时,指针已经指向了末尾
fr.seek(0)#别再忘了,球球了,因为这个想了半个小时

count(t)
print("{} words in all".format(word(fr)))
print(key)
print(shift(t,key))

fr.close()

题目:
【问题描述】

读取文件mayun.txt,完成以下操作:

1.分类统计文件中大写字母、小写字母、数字、空白字符(包括空格、\n、\t等,可用isspace()方法判断)和其他字符的数量

2.输出文件中单词的数量(将其中所有标点符号替换为空格,再根据空格对字符串进行切分可以得到元素为单词的列表。数字按单词统计,如“ 1994” 计算一个单词)

3.用恺撒加密方法对上述文件内容进行加密,为提高加密强度,约定输入一个秘密单词来产生偏移量,偏移量计算方法为先计算用户输入的字符串中每个字符的ASCII值的和,再对26取模,结果作为偏移量。为避免偏移量恰好为0,本题约定秘密单词为用于表示星期几的单词,即’Monday’, ‘Tuesday’, ‘Wednesday’, ‘Thursday’, ‘Friday’, ‘Saturday’, 'Sunday’中的一个。

在密码学中,凯撒密码是一种最简单且最广为人知的加密技术。“恺撒密码”据传是古罗马恺撒大帝用来保护重要军情的加密系统。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推,小写字母也一样处理,其他字符忽略,不作任何改变。

【输入形式】

一个代表星期几的单词,‘Monday’, ‘Tuesday’, ‘Wednesday’, ‘Thursday’, ‘Friday’, ‘Saturday’, 'Sunday’中的一个

【输出形式】

依序输出:‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬

1.文件中大写字母、小写字母、数字、空白字符和其他字符的数量

2.文件中单词的数量

3.偏移量

4.用恺撒加密方法对上述文件内容进行加密的结果

你可能感兴趣的:(Python,python,开发语言,后端)