Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/291.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 使用Twython的代理_Python_Proxy_Python Requests_Twython - Fatal编程技术网

Python 使用Twython的代理

Python 使用Twython的代理,python,proxy,python-requests,twython,Python,Proxy,Python Requests,Twython,每次尝试通过代理运行代码时,我都会遇到此错误。我已经浏览了关于如何让我的代码在代理后运行的每一个链接,但我无法做到这一点 import twython import requests TWITTER_APP_KEY = 'key' #supply the appropriate value TWITTER_APP_KEY_SECRET = 'key-secret' TWITTER_ACCESS_TOKEN = 'token' TWITTER_ACCESS_TOKEN_SECRET = 'sec

每次尝试通过代理运行代码时,我都会遇到此错误。我已经浏览了关于如何让我的代码在代理后运行的每一个链接,但我无法做到这一点

import twython
import requests
TWITTER_APP_KEY = 'key' #supply the appropriate value
TWITTER_APP_KEY_SECRET = 'key-secret' 
TWITTER_ACCESS_TOKEN = 'token'
TWITTER_ACCESS_TOKEN_SECRET = 'secret'


t = twython.Twython(app_key=TWITTER_APP_KEY, 
app_secret=TWITTER_APP_KEY_SECRET, 
oauth_token=TWITTER_ACCESS_TOKEN, 
oauth_token_secret=TWITTER_ACCESS_TOKEN_SECRET,
client_args = {'proxies': {'http': 'proxy.company.com:10080'}})
现在如果我这样做了

t = twython.Twython(app_key=TWITTER_APP_KEY, 
        app_secret=TWITTER_APP_KEY_SECRET, 
        oauth_token=TWITTER_ACCESS_TOKEN, 
        oauth_token_secret=TWITTER_ACCESS_TOKEN_SECRET,
        client_args = client_args)

print t.client_args
我只得到一个{}

当我试着跑步的时候

t.update_status(status='See how easy this was?')
我遇到了这个问题:

Traceback (most recent call last):
File "<pyshell#40>", line 1, in <module>
t.update_status(status='See how easy this was?')
File "build\bdist.win32\egg\twython\endpoints.py", line 86, in update_status
return self.post('statuses/update', params=params)
File "build\bdist.win32\egg\twython\api.py", line 223, in post
return self.request(endpoint, 'POST', params=params, version=version)
File "build\bdist.win32\egg\twython\api.py", line 213, in request
content = self._request(url, method=method, params=params, api_call=url)
File "build\bdist.win32\egg\twython\api.py", line 134, in _request
response = func(url, **requests_args)
File "C:\Python27\lib\site-packages\requests-1.2.3-py2.7.egg\requests\sessions.py",    line 377, in post
return self.request('POST', url, data=data, **kwargs)
File "C:\Python27\lib\site-packages\requests-1.2.3-py2.7.egg\requests\sessions.py", line 335, in request
resp = self.send(prep, **send_kwargs)
File "C:\Python27\lib\site-packages\requests-1.2.3-py2.7.egg\requests\sessions.py", line 438, in send
r = adapter.send(request, **kwargs)
File "C:\Python27\lib\site-packages\requests-1.2.3-py2.7.egg\requests\adapters.py", line 327, in send
raise ConnectionError(e)
ConnectionError: HTTPSConnectionPool(host='api.twitter.com', port=443): Max retries  exceeded with url: /1.1/statuses/update.json (Caused by <class 'socket.gaierror'>: [Errno 11004] getaddrinfo failed)
回溯(最近一次呼叫最后一次):
文件“”,第1行,在
t、 更新_status(status='看看这有多容易?'))
文件“build\bdist.win32\egg\twython\endpoints.py”,第86行,处于更新状态
返回self.post('status/update',params=params)
文件“build\bdist.win32\egg\twython\api.py”,第223行,在post中
返回self.request(端点'POST',params=params,version=version)
请求中第213行的文件“build\bdist.win32\egg\twython\api.py”
content=self.\u请求(url,method=method,params=params,api\u call=url)
文件“build\bdist.win32\egg\twython\api.py”,第134行,在请求中
response=func(url,**请求\参数)
文件“C:\Python27\lib\site packages\requests-1.2.3-py2.7.egg\requests\sessions.py”,第377行,在post中
返回self.request('POST',url,data=data,**kwargs)
文件“C:\Python27\lib\site packages\requests-1.2.3-py2.7.egg\requests\sessions.py”,请求中第335行
resp=自我发送(准备,**发送)
文件“C:\Python27\lib\site packages\requests-1.2.3-py2.7.egg\requests\sessions.py”,第438行,在send中
r=适配器.send(请求,**kwargs)
文件“C:\Python27\lib\site packages\requests-1.2.3-py2.7.egg\requests\adapters.py”,第327行,在send中
升起连接器错误(e)
ConnectionError:HTTPSConnectionPool(host='api.twitter.com',port=443):url:/1.1/statuses/update.json超过了最大重试次数(原因:[Errno 11004]getaddrinfo失败)
我到处都找过了。尽我所能尝试了一切。唯一可用的资源是:

这里也没有我能找到的主题(关于堆栈溢出)


请帮忙。希望有人回复。如果您已经这样做了,请帮助我提供一些代码示例。

看起来域名查找失败。假设您配置的DNS服务器可以解析Twitter的域名(当然也可以),我认为您对
proxy.company.com
的DNS查找失败。尝试按IP地址而不是主机名使用代理。

域名查找似乎失败。假设您配置的DNS服务器可以解析Twitter的域名(当然也可以),我认为您对
proxy.company.com
的DNS查找失败。尝试按IP地址而不是主机名使用代理。

您的代码没有使用代理。该示例显示,您为纯
HTTP
指定了一个代理,但您的stackstrace显示了一个
HTTPSConnectionPool
。您的本地计算机可能无法解析外部域

尝试如下设置代理:

client_args = {'proxies': {'https': 'http://proxy.company.com:10080'}}

你的代码没有使用你的代理。该示例显示,您为纯
HTTP
指定了一个代理,但您的stackstrace显示了一个
HTTPSConnectionPool
。您的本地计算机可能无法解析外部域

尝试如下设置代理:

client_args = {'proxies': {'https': 'http://proxy.company.com:10080'}}

结合@t-8ch的回答(即您必须使用他定义的代理),您还应该意识到,到目前为止,请求(Twython的底层库)不支持通过HTTPS进行代理。这是库urllib3下的请求的问题。据我所知,这是一个长期存在的问题

最重要的是,读一点Twython的解释为什么
t.client\u args
返回一个空字典。简言之,如果您改为打印
t.client.proxies
,您将看到您的代理确实正在按其应有的方式进行处理


最后,在StackOverflow上抱怨您的工作场所,并链接到GitHub提交,这些提交在评论中包含您的GitHub用户名(和真实姓名)并不是最好的主意。StackOverflow被Google完全索引,毫无疑问,其他人可能会找到它,并像我一样轻松地将它与您联系起来。除此之外,这一承诺对Twython目前的行为毫无影响。通过追踪提交的作者,您正在无止境地陷入一个兔子洞。

结合@t-8ch的回答(即您必须使用他定义的代理),您还应该意识到,到目前为止,请求(Twython的底层库)不支持通过HTTPS进行代理。这是库urllib3下的请求的问题。据我所知,这是一个长期存在的问题

最重要的是,读一点Twython的解释为什么
t.client\u args
返回一个空字典。简言之,如果您改为打印
t.client.proxies
,您将看到您的代理确实正在按其应有的方式进行处理


最后,在StackOverflow上抱怨您的工作场所,并链接到GitHub提交,这些提交在评论中包含您的GitHub用户名(和真实姓名)并不是最好的主意。StackOverflow被Google完全索引,毫无疑问,其他人可能会找到它,并像我一样轻松地将它与您联系起来。除此之外,这一承诺对Twython目前的行为毫无影响。你在无止境地追逐那次提交的作者。

从你的书面记录来看,当你打算打印
t.client\u arg时,你似乎打印了
t.client\u arg
。你确定你在那里印的是对的吗?我已经改正了。我正在打印
t.client\u args
。谢谢你指出这一点。但问题仍然存在。从您的书写过程来看,似乎您在打算打印
t.client\u arg
时打印了
t.client\u arg
。你确定你在那里印的是对的吗?我已经改正了。我正在打印
t.client\u args
。谢谢你指出这一点。但问题依然存在。我