首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用python3检查亵渎

如何使用python3检查亵渎
EN

Stack Overflow用户
提问于 2015-06-26 02:02:54
回答 2查看 1.6K关注 0票数 0

请用代码帮我纠正这个问题:

代码语言:javascript
复制
import urllib.request
import urllib.parse

def read_text():

    quotes= open("C:\\Users\\no1\\Desktop\\movie_quotes.txt")
    content_of_file=quotes.read()
    quotes.close()
    check_profanity(content_of_file)

def check_profanity(text_to_check):
    a=urllib.parse.urlencode(text_to_check)
    a=a.encode('utf-8')
    connection=urllib.request.urlopen("http://www.wdyl.com/profanity?q=",a)
    output=connection.read()
    print(output)
    connection.close()

read_text()

我想检查亵渎,但代码不起作用。

以下是来自python的反馈:

代码语言:javascript
复制
Traceback (most recent call last):
  File "C:\Python34\lib\urllib\parse.py", line 760, in urlencode
    raise TypeError
TypeError

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\no1\Desktop\check profanity.py", line 19, in <module>
    read_text()
  File "C:\Users\no1\Desktop\check profanity.py", line 9, in read_text
    check_profanity(content_of_file)
  File "C:\Users\no1\Desktop\check profanity.py", line 12, in check_profanity
    a=urllib.parse.urlencode(text_to_check)
  File "C:\Python34\lib\urllib\parse.py", line 768, in urlencode
    "or mapping object").with_traceback(tb)
  File "C:\Python34\lib\urllib\parse.py", line 760, in urlencode
    raise TypeError
TypeError: not a valid non-string sequence or mapping object
EN

回答 2

Stack Overflow用户

发布于 2017-11-26 02:06:31

www.wdyl.com不再起作用了。

你可以使用你喜欢的:http://www.wdylike.appspot.com/?q=foo

这是我的工作代码:

代码语言:javascript
复制
import urllib.request
import urllib.parse

def read_text():
    quotes = open("movie_quotes.txt")  # Returns a `file` object
    contents_of_file = quotes.read()
    print(contents_of_file)
    quotes.close()
    check_profanity(contents_of_file)

def check_profanity(text_to_check):
    encoded_text = urllib.parse.quote(text_to_check, 'utf-8')
    address = "http://www.wdylike.appspot.com/?q="+encoded_text
    print(address)
    connection = urllib.request.urlopen(address)
    output = connection.read()
    print(output)
    connection.close()

read_text()
票数 2
EN

Stack Overflow用户

发布于 2015-06-26 06:18:23

下面是另一种类似的方式:

代码语言:javascript
复制
from django.utils.encoding import smart_str
import urllib

def check_profanity(to_check):
    try:
        connection = urllib.urlopen('http://www.wdyl.com/profanity?q='\ 
                    + smart_str(to_check))
        output = connection.read()
        connection.close()
        if 'true' in output:  
            return True
        else:
            return False  
    except:
        print "An error occurred!"
        return
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31057532

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档