本文介紹了Python3 錯(cuò)誤:TypeError:無法將“字節(jié)"對象隱式轉(zhuǎn)換為 str的處理方法,對大家解決問題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!
問題描述
我正在 learnpythonthehardway 中的練習(xí) 41 并不斷收到錯(cuò)誤:
I am working on exercise 41 in learnpythonthehardway and keep getting the error:
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
我使用的是python3,而書籍使用的是python2,所以我做了一些更改.這是腳本:
I am using python3 while the books uses python2, so I have made some changes. Here is the script:
#!/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):
def __init__(self, ***)" :
"class ### has-a __init__ that takes self and *** parameters.",
"class ###(object):
def ***(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: {}
".format(answer))
except EOFError:
print("
Bye")
我到底做錯(cuò)了什么?謝謝!
What exactly am I doing wrong here? Thanks!
推薦答案
urlopen()
返回一個(gè)字節(jié)對象,要對其執(zhí)行字符串操作,您應(yīng)該將其轉(zhuǎn)換為 str
首先.
urlopen()
returns a bytes object, to perform string operations over it you should convert it to str
first.
for word in urlopen(WORD_URL).readlines():
WORDS.append(word.strip().decode('utf-8')) # utf-8 works in your case
要獲得正確的字符集:如何下載python中有正確字符集的任何(!)網(wǎng)頁嗎?
這篇關(guān)于Python3 錯(cuò)誤:TypeError:無法將“字節(jié)"對象隱式轉(zhuǎn)換為 str的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!
【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!