这个错误信息表明在你的Python程序中,re.search()
函数没有找到预期的匹配项,因此返回了 None
。当你尝试在 None
对象上调用 group(1)
方法时,Python 抛出了一个 AttributeError
。
具体来说,错误发生在 pc.py
文件的第6行,你试图从一个字符串 text_response
中提取一个数字,这个数字位于 actual_page:52 (\d+), //真实页数
这个模式的匹配结果中。但是,re.search()
没有找到这个模式,所以返回了 None
。
要解决这个问题,你可以采取以下几个步骤:
-
检查
text_response
内容:
确保text_response
包含你期望搜索的字符串。可能的情况是,text_response
的内容不是你预期的,或者格式有变。 -
验证正则表达式:
确保你的正则表达式actual_page:52 (\d+), //真实页数
是正确的。这里的\d+
是用来匹配一个或多个数字的,但前面的actual_page:52
看起来像是硬编码的数字,这可能不是通用的匹配方式。如果actual_page
后面的数字(这里是52)是变化的,那么你的正则表达式需要调整以匹配变化的数字。 -
处理
None
返回值:
在调用group(1)
之前,你应该检查re.search()
的返回值是否为None
。如果是None
,你可以添加一些错误处理逻辑,比如打印一个错误消息或者设置一个默认值 -
调整正则表达式以匹配更多情况:
如果actual_page
后面的数字是变化的,你可以使用更通用的模式,如actual_page:\d+ (\d+), //真实页数
。
通过上述步骤,你应该能够定位问题并修正它。如果问题仍然存在,可能需要进一步检查 text_response
的来源和格式。
代码:import requests, json, re, time, urllib.requestdef getParameter(url): # 获取文档参数text_response = requests.get(url=url, headers=headers).textactual_page = int(re.search('actual_page:52 (\d+), //真实页数', text_response).group(1)) # 页数aid = re.search('aid:456032948 (\d+), //解密后的id', text_response).group(1) # aidview_token = re.search('view_token:fTywuwW@c2Kh7QLBNdnrdxk0il5mF58mQT57vGVOPDc= \'(.*?)\'', text_response).group(1) # view_tokenprint('actual_page:', actual_page, '\naid:', aid, '\nview_token:', view_token)return actual_page, aid, view_tokendef requests_data(parameter, page): # 请求数据url = 'https://openapi.book118.com/getPreview.html'params = {'project_id': '1','aid': parameter[1],'view_token': parameter[2],'page': page,}response = requests.get(url=url, headers=headers, params=params).textjson_data = re.search('jsonpReturn\((.*?)\);', response).group(1) # 使用正则表达式所需数据data = json.loads(json_data)['data']# if data.get(str(page)) == '': # 根据需求使用# print('数据加载失败,重新发出请求')# time.sleep(1)# return requests_data(parameter, page)# time.sleep(1)return get_data(data)def get_data(data): # 下载数据for i in data.items(): # i[0]为页数,i[1]为网址img_url = 'https:' + i[1]# urllib.request.urlretrieve(url=img_url, filename=r'D:/yuanChuangLi/{}.png'.format(i[0])) # 下载图片print(i[0], img_url)if __name__ == '__main__':headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36'}text_url = input('输入网址:')parameter = getParameter(text_url)for page in range(1, parameter[0], 6):requests_data(parameter, page)