[Python-bugs-list] [ python-Bugs-807771 ] Max and min are incorrect
with one argument
SourceForge.net
noreply at sourceforge.net
Sun Sep 28 20:47:18 EDT 2003
Bugs item #807771, was opened at 2003-09-17 07:49
Message generated for change (Comment added) made by tjreedy
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=807771&group_id=5470
Category: Python Library
Group: Python 2.2.3
Status: Closed
Resolution: Invalid
Priority: 5
Submitted By: Greg Kochanski (gpk)
Assigned to: Nobody/Anonymous (nobody)
Summary: Max and min are incorrect with one argument
Initial Comment:
max(1)
raises 'TypeError: iteration over non-sequence',
when it should simply return 1
Min has the same problem.
If there is one person in a room, and you ask for the
tallest person, there is a well-defined answer.
The tallest person is the only person.
So is the shortest person.
I ran across this when I was doing
apply(max, list) / apply(min, list)
to find out the ratio of maximum to minimum entries
in a list. With a single-element list, I expected
it to return 1, instead of raising an exception.
----------------------------------------------------------------------
Comment By: Terry J. Reedy (tjreedy)
Date: 2003-09-28 20:47
Message:
Logged In: YES
user_id=593130
I think the gimmick of having a function of 1-m arguments
treat one arg as a sequence is a design bug that asks for
problems. With the addition of *seq, it is even more
unnecessary. But for backwards compatibility, it must
remain until 3.0.
Greg: you faked yourself out by using apply.
Go with the flow and just use max(list)/min(list):
>>> max([2])/min([2])
1
----------------------------------------------------------------------
Comment By: Raymond Hettinger (rhettinger)
Date: 2003-09-22 15:24
Message:
Logged In: YES
user_id=80475
That behavior is consequence of interpreting a single
argument as an input sequence while interpreting multiple
arguments as the sequence itself.
Given a single argument, Python could make some
reasonable guesses: max(3) --> 3 and max((3,4)) --> 4,
but guessing is not the Pythonic way. Also, I think max(x)
tends to be an error condition when x is not iterable, so it
would be unwise to simply return x and let the error pass
silently.
If it makes you feels better, you *are* the tallest, smartest,
and richest OP for this bug report ;-)
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=807771&group_id=5470
More information about the Python-bugs-list
mailing list