2017-02-02 5 views
0

ТНХ !! 1. Похоже, ошибка STH в нем, но я не смог найти его 2. Так это, но теперь следует код. блок:Python «TypeError:„builtin_function_or_method“объект не subscriptable»

from urllib.request import Request, urlopen 
from urllib.error import URLError,HTTPError 
from bs4 import BeautifulSoup 
import re 

print('https://v.qq.com/x/page/h03425k44l2.html\\\\n\\\\https://v.qq.com/x/cover/dn7fdvf2q62wfka/m0345brcwdk.html\\\\n\\\\http://v.qq.com/cover/2/2iqrhqekbtgwp1s.html?vid=c01350046ds') 
web = input('请输入网址:') 
if re.search(r'vid=',web) : 
    patten =re.compile(r'vid=(.*)') 
    vid=patten.findall(web) 
    vid=vid[0] 

else: 
    newurl = (web.split("/")[-1]) 
    vid =newurl.replace('.html', ' ') 
#从视频页面找出vid 

getinfo='http://vv.video.qq.com/getinfo?vids{vid}&otype=xlm&defaultfmt=fhd'.format(vid=vid.strip()) 
def getpage(url): 
    req = Request(url) 
    user_agent = 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit' 
    req.add_header('User-Agent', user_agent) 
    try: 
     response = urlopen(url) 
    except HTTPError as e: 
     print('The server couldn\\\'t fulfill the request.') 
     print('Error code:', e.code) 
    except URLError as e: 
     print('We failed to reach a server.') 
     print('Reason:', e.reason) 
    html = response.read().decode('utf-8') 
    return(html) 
#打开网页的函数 

a = getpage(getinfo) 

soup = BeautifulSoup(a, "html.parser") 
for e1 in soup.find_all('url'): 
    ippattent = re.compile(r"((?:(2[0-4]\\\\d)|(25[0-5])|([01]\\\\d\\\\d?))\\\\.){3}(?:(2[0-4]\\\\d)|(255[0-5])|([01]?\\\\d\\\\d?))") 
    if re.search(ippattent,e1.get_text()): 
     ip=(e1.get_text()) 
for e2 in soup.find_all('id'): 
    idpattent = re.compile(r"\\\\d{5}") 
    if re.search(idpattent,e2.get_text()): 
     id=(e2.get_text()) 
filename=vid.strip()+'.p'+id[2:]+'.1.mp4' 
#找到ID和拼接FILENAME 

getkey='http://vv.video.qq.com/getkey?format={id}&otype=xml&vt=150&vid{vid}&ran=0%2E9477521511726081\\\\&charge=0&filename={filename}&platform=11'.format(id=id,vid=vid.strip(),filename=filename) 
#利用getinfo中的信息拼接getkey网址 
b = getpage(getkey) 

key=(re.findall(r'<key>(.*)<\\\\/key>',b)) 

videourl=ip+filename+'?'+'vkey='+key[0] 

print('视频播放地址 '+videourl) 
#完成了 

я запускаю его и получить это:

Traceback (most recent call last): 
    File "C:\Users\DYZ_TOGA\Desktop\qq.py", line 46, in <module> 
    filename=vid.strip()+'.p'+id[2:]+'.1.mp4' 
TypeError: 'builtin_function_or_method' object is not subscriptable 

Что я должен делать, я не знаю, как изменить свой код, чтобы исправить it.thank вам :)

ответ

0

корень вашей проблемы здесь:

if re.search(idpattent,e2.get_text()): 
    id=(e2.get_text()) 

Если это ложь, вы никогда не ставили id. И это означает, что id - это встроенная функция этого имени, которая получает уникальный идентификатор любого объекта. Поскольку это функция, а не строка, которую вы ожидаете, вы не можете этого сделать:

id[2:] 

Следовательно, ошибка, которую вы получаете.

Мои предложения являются:

  1. Используйте другое имя переменной; вы бы получили ошибку об этом, не определяясь в этом случае, что облегчило бы решение проблемы.

  2. Если вы не нашли идентификатор, не продолжайте сценарий; это не сработает. Если вы ожидали найти его и не знаете, почему этого не происходит, это другой вопрос, который вы должны задать отдельно.

0

id - встроенная функция в python. кажется, вы используете то же самое для хранения переменной. Плохая привычка использовать ключевое слово как имя переменной. Вместо этого используйте другое имя.

0
if re.search(idpattent,e2.get_text()): 
     id=(e2.get_text()) 
filename=vid.strip()+'.p'+id[2:]+'.1.mp4' 

Если выше «если» не соответствует действительности, идентификатор не будет установлен на значение строки.

По умолчанию id является функцией python. Поэтому вы не можете сделать id [2:]

потому что python ожидает id().

Смежные вопросы