Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

Urllib2 urlopen and read - difference

8 views
Skip to first unread message

koranthala

unread,
Apr 15, 2010, 2:25:55 PM4/15/10
to
Hi,
Suppose I am doing the following:
req = urllib2.urlopen('http://www.python.org')
data = req.read()

When is the actual data received? is it done by the first line? or
is it done only when req.read() is used?
My understanding is that when urlopen is done itself, we would have
received all the data, and req.read() just reads it from the file
descriptor.
But, when I read the source code of pylot, it mentioned the
following:
resp = opener.open(request) # this sends the HTTP request
and returns as soon as it is done connecting and sending
connect_end_time = self.default_timer()
content = resp.read()
req_end_time = self.default_timer()

Here, it seems to suggest that the data is received only after you do
resp.read(), which made me all confused.

If someone could help me out, it would be much helpful.

J. Cliff Dyer

unread,
Apr 15, 2010, 2:55:20 PM4/15/10
to koranthala, pytho...@python.org

My understanding (please correct me if I'm wrong), is that when you call
open, you send a request to the server, and get a response object back.
The server immediately begins sending data (you can't control when they
send it, once you've requested it). When you call read() on your
response object, it reads all the data it has already received, and if
that amount of data isn't sufficient to handle your read call, it blocks
until it has enough.

So your opener returns as soon as the request is sent, and read() blocks
if it doesn't have enough data to handle your request.

Cheers,
Cliff

J. Cliff Dyer

unread,
Apr 15, 2010, 2:56:00 PM4/15/10
to koranthala, pytho...@python.org
On Thu, 2010-04-15 at 11:25 -0700, koranthala wrote:

My understanding (please correct me if I'm wrong), is that when you call

Aahz

unread,
Apr 25, 2010, 10:13:29 PM4/25/10
to
In article <mailman.1917.1271357...@python.org>,

J. Cliff Dyer <j...@sdf.lonestar.org> wrote:
>On Thu, 2010-04-15 at 11:25 -0700, koranthala wrote:
>>
>> Suppose I am doing the following:
>> req = urllib2.urlopen('http://www.python.org')
>> data = req.read()
>>
>> When is the actual data received? is it done by the first line? or
>> is it done only when req.read() is used?
>> My understanding is that when urlopen is done itself, we would have
>> received all the data, and req.read() just reads it from the file
>> descriptor.
>> But, when I read the source code of pylot, it mentioned the
>> following:
>> resp = opener.open(request) # this sends the HTTP request
>> and returns as soon as it is done connecting and sending
>> connect_end_time = self.default_timer()
>> content = resp.read()
>> req_end_time = self.default_timer()
>>
>> Here, it seems to suggest that the data is received only after you do
>> resp.read(), which made me all confused.
>
>My understanding (please correct me if I'm wrong), is that when you call
>open, you send a request to the server, and get a response object back.
>The server immediately begins sending data (you can't control when they
>send it, once you've requested it). When you call read() on your
>response object, it reads all the data it has already received, and if
>that amount of data isn't sufficient to handle your read call, it blocks
>until it has enough.
>
>So your opener returns as soon as the request is sent, and read() blocks
>if it doesn't have enough data to handle your request.

Close. urlopen() returns after it receives the HTTP header (that's why
you can get an HTTP exception on e.g. 404 without the read()).
--
Aahz (aa...@pythoncraft.com) <*> http://www.pythoncraft.com/

"It is easier to optimize correct code than to correct optimized code."
--Bill Harlan

0 new messages