函数返回多个值是pythonic吗?

Rea*_*nly 80 python function return-value multiple-return-values

在python中,您可以让函数返回多个值.这是一个人为的例子:

def divide(x, y):
    quotient = x/y
    remainder = x % y
    return quotient, remainder  

(q, r) = divide(22, 7)
Run Code Online (Sandbox Code Playgroud)

这似乎非常有用,但看起来它也可能被滥用("嗯......功能X已经计算出我们需要的中间值.让我们让X返回那个值").

你什么时候画线并定义一个不同的方法?

jfs*_*jfs 105

绝对(就你提供的例子而言).

元组是Python中的一等公民

有一个内置函数divmod()正是这样做的.

q, r = divmod(x, y) # ((x - x%y)/y, x%y) Invariant: div*y + mod == x
Run Code Online (Sandbox Code Playgroud)

还有其他的例子:zip,enumerate,dict.items.

for i, e in enumerate([1, 3, 3]):
    print "index=%d, element=%s" % (i, e)

# reverse keys and values in a dictionary
d = dict((v, k) for k, v in adict.items()) # or 
d = dict(zip(adict.values(), adict.keys()))
Run Code Online (Sandbox Code Playgroud)

顺便说一下,括号在大多数情况下都不是必需的.Python库参考引文:

元组可以通过多种方式构建:

  • 使用一对括号表示空元组:()
  • 对单例元组使用尾随逗号:a或(a,)
  • 用逗号分隔项目:a,b,c或(a,b,c)
  • 使用内置的元组():tuple()或元组(可迭代)

功能应该用于单一目的

因此他们应该返回一个对象.在你的情况下,这个对象是一个元组.将元组视为ad-hoc复合数据结构.有些语言几乎每个函数都返回多个值(Lisp中的列表).

有时返回(x, y)而不是返回Point(x, y).

命名为元组

通过在Python 2.6中引入命名元组,在许多情况下,最好返回命名元组而不是普通元组.

>>> import collections
>>> Point = collections.namedtuple('Point', 'x y')
>>> x, y = Point(0, 1)
>>> p = Point(x, y)
>>> x, y, p
(0, 1, Point(x=0, y=1))
>>> p.x, p.y, p[0], p[1]
(0, 1, 0, 1)
>>> for i in p:
...   print(i)
...
0
1
Run Code Online (Sandbox Code Playgroud)

  • 非常感谢你提到了名为元组的元组.我一直在找这样的东西. (3认同)

Jas*_*dge 27

首先,请注意Python允许以下内容(不需要括号):

q, r = divide(22, 7)
Run Code Online (Sandbox Code Playgroud)

关于你的问题,任何方式都没有硬性规定.对于简单(通常是人为的)示例,似乎给定函数始终可以具有单一目的,从而产生单个值.但是,在将Python用于实际应用程序时,很快就会遇到需要返回多个值的许多情况,从而使代码更加清晰.

所以,我会说做任何有意义的事情,不要试图遵循一个人为的约定.Python支持多个返回值,因此请在适当时使用它.

  • 逗号创建元组,因此表达式:`q,r`*是*元组. (4认同)

Nat*_*nes 13

你给出的例子实际上是一个python内置函数,叫做divmod.所以有人在某个时候认为它足够pythonic包含在核心功能中.

对我而言,如果它使代码更清晰,它就是pythonic.比较这两个代码块:

seconds = 1234
minutes, seconds = divmod(seconds, 60)
hours, minutes = divmod(minutes, 60)

seconds = 1234
minutes = seconds / 60
seconds = seconds % 60
hours = minutes / 60
minutes = minutes % 60
Run Code Online (Sandbox Code Playgroud)