Iterators from urllib2

Michael Hoffman cam.ac.uk at mh391.invalid
Fri Jul 22 11:15:14 EDT 2005


Joshua Ginsberg wrote:
> I'm a bit baffled by something...
> 
> In a script I wrote, I have defined a function that runs  
> urllib2.urlopen() on a urllib2.Request object and returns the file-like  
> object. The code that calls this function attempts to build a  
> csv.DictReader object based on that file-like object, but an error is  
> thrown saying the file-like object is not an iterator.
> 
> I could have sworn urllib2.urlopen returned an iterator, so I tested:
> 
> Python 2.3 (#1, Sep 13 2003, 00:49:11)
> [GCC 3.3 20030304 (Apple Computer, Inc. build 1495)] on darwin
> Type "help", "copyright", "credits" or "license" for more information.
>  >>> import urllib2
>  >>> r = urllib2.Request('http://www.google.com')
>  >>> ifs = urllib2.urlopen(r)
>  >>> dir(ifs)
> ['__doc__', '__init__', '__iter__', '__module__', '__repr__', 'close',  
> 'fileno', 'fp', 'geturl', 'headers', 'info', 'next', 'read',  
> 'readline', 'readlines', 'url']
> 
> Yep. But what about in my code? I modify my code to print dir(ifs)  
> before creating the DictReader...
> 
> ['__doc__', '__init__', '__module__', '__repr__', 'close', 'fp',  
> 'geturl', 'headers', 'info', 'read', 'readline', 'url']
> Traceback (most recent call last):
>   File "CSVParser.py", line 144, in ?
>     print parseQHost(circuits[cktname], cktname)
>   File "CSVParser.py", line 126, in parseQHost
>     r = csv.DictReader(ifs, fieldlist)
>   File  "/System/Library/Frameworks/Python.framework/Versions/2.3/lib/ 
> python2.3/csv.py", line 100, in __init__
>     self.reader = reader(f, dialect, *args)
> TypeError: argument 1 must be an iterator
> 
> Whoa! Where did the __iter__, readlines, and next attributes go? Ideas?

Works for me on Python 2.4.1.
-- 
Michael Hoffman



More information about the Python-list mailing list