用爬虫完成扇贝的单词测试

作者: gavin 分类: Python,爬虫技术 发布时间: 2020-10-21 19:42
import requests

# 先用requests请求链接
link = requests.get('https://www.shanbay.com/api/v1/vocabtest/category/')
# 解析请求得到的响应
js_link = link.json()

# 让用户选择自己想测的词库,输入数字编号。int()来转换数据类型
bianhao = int(input('''请输入你选择的词库编号,按Enter确认
1,GMAT  2,考研  3,高考  4,四级  5,六级
6,英专  7,托福  8,GRE  9,雅思  10,任意
>'''))
# 利用用户输入的数字编号,获取题库的代码。如果以输入“高考”的编号“3”为例,那么ciku的值就是,在字典js_link中查找data的值,data是一个list,查找它的第bianhao-1,也就是第2个元素,得到的依然是一个list,再查找该list的第0个元素。最后得到的就是我们想要的NCEE。
ciku = js_link['data'][bianhao-1][0]
# 请求(获取)用于测试的50个单词。
test = requests.get('https://www.shanbay.com/api/v1/vocabtest/vocabularies/?category='+ciku)
# 对响应test进行解析。
words = test.json()
# 新增一个list,用于统计用户认识的单词
danci = []
# 创建一个空的列表,用于记录用户认识的单词。
words_knows = []
# 创建一个空的列表,用于记录用户不认识的单词。
not_knows = []

print ('测试现在开始。如果你认识这个单词,请输入Y,否则直接敲Enter:')

# 启动一个循环,循环的次数等于单词的数量。
n=0
for x in words['data']:
    n=n+1
    print ("\n第"+str(n)+'个:'+x['content']) # 加一个\n,用于换行。
    # 让用户输入自己是否认识。
    #################################################
    #answer = input('认识请敲Y,否则敲Enter:')
    answer = 'Y'
    #################################################
     # 如果用户认识:
    if answer == 'Y':
        danci.append(x['content'])
        # 就把这个单词,追加进列表words_knows。
        words_knows.append(x)

    # 否则
    else:
        # 就把这个单词,追加进列表not_knows。
        not_knows.append(x)



print ('\n在上述'+str(len(words['data']))+'个单词当中,有'+str(len(danci))+'个是你觉得自己认识的,它们是:')
print(danci)

print ('现在我们来检测一下,你有没有真正掌握它们:')
wrong_words = []
right_num = 0
for y in words_knows:
    print(y)
    # 我们改用A、B、C、D,不再用rank值
    print('\n\n'+'A:'+y['definition_choices'][0]['definition'])
    print('B:'+y['definition_choices'][1]['definition'])
    print('C:'+y['definition_choices'][2]['definition'])
    print('D:'+y['definition_choices'][3]['definition'])
    #################################################
    #xuanze = input('请选择单词\"'+y['content']+'\"的正确翻译(输入字母即可):')
    if y['definition_choices'][0]['rank'] == y['rank']:
        xuanze = 'A'
    elif y['definition_choices'][1]['rank'] == y['rank']:
        xuanze = 'B'
    elif y['definition_choices'][2]['rank'] == y['rank']:
        xuanze = 'C'
    else:
        xuanze = 'D'
    xuanze = 'D'
    #################################################
    # 我们创建一个字典,搭建起A、B、C、D和四个rank值的映射关系。
    dic = {'A':y['definition_choices'][0]['rank'],'B':y['definition_choices'][1]['rank'],'C':y['definition_choices'][2]['rank'],'D':y['definition_choices'][3]['rank']}
    # 此时dic[xuanze]的内容,其实就是rank值,此时的代码含义已经和之前的版本相同了。
    if dic[xuanze] == y['rank']:
        right_num += 1
    else:
        wrong_words.append(y)

print ('现在,到了公布成绩的时刻:')
# 以下是句蛮复杂的话,对照前面的代码和json文件你才能理解它。一个运行示例是:在50个高考词汇当中,你认识其中30个,实际掌握25个,错误5个。
print ('在'+str(len(words['data']))+'个'+js_link['data'][bianhao-1][1]+'词汇当中,你认识其中'+str(len(danci))+'个,实际掌握'+str(right_num)+'个,错误'+str(len(wrong_words))+'个。')

# 询问用户,是否要打印并保存错题集。
save = input ('是否打印并保存你的错词集?填入Y或N: ')
# 如果用户说是:
if save == 'Y':
    # 在当前目录下,创建一个错题集.txt的文档。
    f = open('错题集.txt', 'a+')
    print ('你记错的单词有:')
    # 写入"你记错的单词有:\n"
    f.write('你记错的单词有:\n')

    # 启动一个循环,循环的次数等于,用户的错词数:
    m=0
    for z in wrong_words:
        m = m+1
        # 打印每一个错词。
        print (z['content'])
        #打印每一个错词。
        f.write(str(m) +'. '+ z['content']+'\n')
        #写入序号,写入错词。
    print ('你不认识的单词有:')
    # 写入"你没记住的单词有:\n"
    f.write('你没记住的单词有:\n')

    # 启动一个循环,循环的次数等于,用户不认识的单词数。
    s=0
    for x in not_knows:
    #启动一个循环,循环的次数等于,用户不认识的单词数。
        s=s+1
        print (x['content'])
        #打印每一个不认识的单词。
        f.write(str(s) +'. '+ x['content']+'\n')
        #写入序号,写入用户不认识的词汇。
    print ('错词和没记住的词已保存至当前文件目录下,下次见!')

# 如果用户不想保存:
else:
    # 输出“下次见!”
    print('下次见!')

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注