On 1/29/2019 7:12 PM, MRAB wrote:
On 2019-01-29 23:30, Terry Reedy wrote:
On 1/28/2019 8:40 PM, Jamesie Pic wrote:

  > 0. os.path.join takes *args

Since at least 1 path is required, the signature is join(path, *paths).
I presume that this is the Python version of the Unix version of the
system call that it wraps..  The hidden argument is os.sep.  It is
equivalent to os.sep.join((path,)+paths) (though one would not write it
this way).

1. str.join takes a list argument,

This premise behind the (repeated) request is a false.  str.joins
arguments are a string (the joiner) and an *iterable of strings*, which
is an abstract subclass of the abstract concept 'iterable'.  And only a
small fraction of lists are lists of strings and therefore iterables of
strings.

One the examples given was writing:

 >>> '/'.join('some', 'path')

To me, this suggests that what the OP _really_ wants is for str.join to accept multiple arguments, much as os.path.join does.

I thought that there would be a problem with that because currently the single argument is an iterable, and you wouldn't want to iterate the first argument of '/'.join('some', 'path').



However, both min and max will accept either a single argument that's iterated over or multiple arguments that are not, so there's a precedent there.

I have done things like this in private code, but it makes for messy signatures. The doc pretends that min has two signatures, given in the docstring:

    min(iterable, *[, default=obj, key=func]) -> value
    min(arg1, arg2, *args, *[, key=func]) -> value

I believe that the actual signature is the uninformative min(*args, **kwargs). The arg form, without key, is the original. If min were being written today, I don't think it would be included.

--
Terry Jan Reedy


_______________________________________________
Python-ideas mailing list
Python-ideas@python.org
https://mail.python.org/mailman/listinfo/python-ideas
Code of Conduct: http://python.org/psf/codeofconduct/

Reply via email to