我正在研究Udacity的一个教训,并且在尝试查看此站点的结果是返回true还是false时遇到了一些问题.我使用下面的代码获得TypeError.
- from urllib.request import urlopen
- #check text for curse words
- def check_profanity():
- f = urlopen("http://www.wdylike.appspot.com/?q=shit")
- output = f.read()
- f.close()
- print(output)
- if "b'true'" in output:
- print("There is a profane word in the document")
- check_profanity()
输出打印b’true’,我不确定’b’来自哪里.
解决方法
在python 3中,字符串默认为unicode. b’true’中的b表示字符串是字节字符串而不是unicode.如果你不希望你能做到:
- from urllib.request import urlopen
- #check text for curse words
- def check_profanity():
- with urlopen("http://www.wdylike.appspot.com/?q=shit") as f:
- output = f.read().decode('utf-8')
- if output:
- if "true" in output:
- print("There is a profane word in the document")
- check_profanity()