我在理解这个python代码的语法时遇到了一些问题。有问题的代码是一个简单的电报聊天机器人,它通过从https门中提取更新来工作。
URL = "https://api.telegram.org/bot{}/".format(TOKEN)
def get_url(url):
response = mechanize.urlopen(url)
content = response.read()
return content
def get_json_from_url(url):
content = get_url(url)
js = json.loads(content)
return js
def get_updates(offset=None):
url = URL + "getUpdates"
if offset:
url += "?offset={}".format(offset)
js = get_json_from_url(url)
return js
def get_last_update_id(updates):
update_ids = []
for update in updates["result"]:
update_ids.append(int(update["update_id"]))
return max(update_ids)
def echo_all(updates):
for update in updates["result"]:
text = update["message"]["text"]
chat = update["message"]["chat"]["id"]
send_message(text, chat)
def get_last_chat_id_and_text(updates):
num_updates = len(updates["result"])
last_update = num_updates - 1
text = updates["result"][last_update]["message"]["text"]
chat_id = updates["result"][last_update]["message"]["chat"]["id"]
return (text, chat_id)
据我所知,在这种情况下,JSON 的用处几乎为零,因为 mechanize 返回 UTF-8 str。但是,在运行时
def main():
last_update_id = None
while True:
updates = get_updates(last_update_id)
if len(updates["result"]) > 0:
last_update_id = get_last_update_id(updates) + 1
#echo_all(updates)
send_stdmessage(updates)
我收到以下错误:
Traceback (most recent call last):
File "PreAlpha.py", line 70, in <module>
main()
File "PreAlpha.py", line 62, in main
if len(updates["result"]) > 0:
TypeError: 'NoneType' object has no attribute '__getitem__'
而如果我保持该代码部分不变并保持 JSON 不变,代码就会完美运行。
编辑:这是机器人将从中提取的数据中的一个示例:
{"ok":true,"result":[{"update_id":130999147,"message":
{"message_id":24,"from":
{"id":346850522,"first_name":"XXX","last_name":"XXX"},"chat":
{"id":346850522,"first_name":"XXX","last_name":"XXX",
"type":"private"},"date":1489950868,"text":"Hello"}}]}
> 正如@mic4ael所指出的,命令:mechanize.read()
返回一个带有JSON
的str
对象,例如'{"updates":[]}',然后它必须使用json.loads
转换为Python对象(dict
(我错误地认为"mechanize.read(("数据是一个python对象。