the*_*ter 39 python type-conversion typeerror object-to-string
我正在learnpythonthehardway进行练习41并继续得到错误:
Traceback (most recent call last):
File ".\url.py", line 72, in <module>
question, answer = convert(snippet, phrase)
File ".\url.py", line 50, in convert
result = result.replace("###", word, 1)
TypeError: Can't convert 'bytes' object to str implicitly
Run Code Online (Sandbox Code Playgroud)
我使用python3而书籍使用python2,所以我做了一些改动.这是脚本:
#!/usr/bin/python
# Filename: urllib.py
import random
from random import shuffle
from urllib.request import urlopen
import sys
WORD_URL = "http://learncodethehardway.org/words.txt"
WORDS = []
PHRASES = {
"class ###(###):":
"Make a class named ### that is-a ###.",
"class ###(object):\n\tdef __init__(self, ***)" :
"class ### has-a __init__ that takes self and *** parameters.",
"class ###(object):\n\tdef ***(self, @@@)":
"class ### has-a funciton named *** that takes self and @@@ parameters.",
"*** = ###()":
"Set *** to an instance of class ###.",
"***.*** = '***'":
"From *** get the *** attribute and set it to '***'."
}
# do they want to drill phrases first
PHRASE_FIRST = False
if len(sys.argv) == 2 and sys.argv[1] == "english":
PHRASE_FIRST = True
# load up the words from the website
for word in urlopen(WORD_URL).readlines():
WORDS.append(word.strip())
def convert(snippet, phrase):
class_names = [w.capitalize() for w in
random.sample(WORDS, snippet.count("###"))]
other_names = random.sample(WORDS, snippet.count("***"))
results = []
param_names = []
for i in range(0, snippet.count("@@@")):
param_count = random.randint(1,3)
param_names.append(', '.join(random.sample(WORDS, param_count)))
for sentence in snippet, phrase:
result = sentence[:]
# fake class names
for word in class_names:
result = result.replace("###", word, 1)
# fake other names
for word in other_names:
result = result.replace("***", word, 1)
# fake parameter lists
for word in param_names:
result = result.replace("@@@", word, 1)
results.append(result)
return results
# keep going until they hit CTRL-D
try:
while True:
snippets = list(PHRASES.keys())
random.shuffle(snippets)
for snippet in snippets:
phrase = PHRASES[snippet]
question, answer = convert(snippet, phrase)
if PHRASE_FIRST:
question, answer = answer, question
print(question)
input("> ")
print("ANSWER: {}\n\n".format(answer))
except EOFError:
print("\nBye")
Run Code Online (Sandbox Code Playgroud)
我到底错在了什么?谢谢!
Ash*_*ary 30
urlopen()
返回一个bytes对象,对它执行字符串操作,你应该将它转换为str
第一个.
for word in urlopen(WORD_URL).readlines():
WORDS.append(word.strip().decode('utf-8')) # utf-8 works in your case
Run Code Online (Sandbox Code Playgroud)
要获得正确的字符集: 如何在python中下载任何(!)网页和正确的字符集?
aba*_*ert 13
在Python 3中,该urlopen
函数返回一个HTTPResponse
对象,其作用类似于二进制文件.所以,当你这样做时:
for word in urlopen(WORD_URL).readlines():
WORDS.append(word.strip())
Run Code Online (Sandbox Code Playgroud)
...你最终会得到一堆bytes
物体而不是str
物体.所以当你这样做时:
result = result.replace("###", word, 1)
Run Code Online (Sandbox Code Playgroud)
...你最终试图用一个对象替换字符串"###"
中的字符串,而不是.因此错误:result
bytes
str
TypeError: Can't convert 'bytes' object to str implicitly
Run Code Online (Sandbox Code Playgroud)
答案是一旦你得到它们就明确解码这些单词.为此,您必须从HTTP标头中找出正确的编码.你是怎样做的?
在这种情况下,我读了标题,我可以告诉它是ASCII,它显然是一个静态页面,所以:
for word in urlopen(WORD_URL).readlines():
WORDS.append(word.strip().decode('ascii'))
Run Code Online (Sandbox Code Playgroud)
但在现实生活中,您通常需要编写读取标题并动态计算出来的代码.或者,更好的是,安装更高级别的库requests
,这样可以自动为您完成.
归档时间: |
|
查看次数: |
86850 次 |
最近记录: |