我正在编写一个程序,使用urllib2从 http 站点下载 CSV 数据。该程序在 Python 中运行时工作正常,但我也尝试使用argparse能够从命令行输入 url。
当我运行它时,出现以下错误:
File "urlcsv.py", line 51, in downloadData
return urllib2.urlopen(url)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/urllib2.py", line 127, in urlopen
return _opener.open(url, data, timeout)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/urllib2.py", line 396, in open
protocol = req.get_type()
AttributeError: 'Namespace' object has no attribute 'get_type'
我想这是一部分urllib2库,因为它不是我编写的代码。
有没有其他人遇到过类似的问题argparse or urllib2模块?
相关部分代码如下:
parser = argparse.ArgumentParser()
parser.add_argument("url")
def main():
"""Runs when the program is opened"""
args = parser.parse_args()
if args is False:
SystemExit
try:
csvData = downloadData(args)
except urllib2.URLError:
print 'Please try a different URL'
raise
else:
LOG_FILENAME = 'errors.log'
logging.basicConfig(filename=LOG_FILENAME,
level=logging.DEBUG,
)
logging.getLogger('assignment2')
personData = processData(csvData)
ID = int(raw_input("Enter a user ID: "))
if ID <= 0:
raise Exception('Program exited, value <= 0')
else:
displayPerson(ID)
main()
def downloadData(url):
return urllib2.urlopen(url)
您正在将命令行参数解析为args
,这是一个Namespace
将属性设置为已解析的参数。但是你将整个命名空间传递给downloadData
,而不仅仅是网址。然后这个命名空间被传递到urlopen
,它不知道该怎么办。相反,请致电downloadData(args.url)
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)