Аналогично использованию varargs в C или С++:
fn(a, b)
fn(a, b, c, d, ...)
Аналогично использованию varargs в C или С++:
fn(a, b)
fn(a, b, c, d, ...)
Да.
Это просто и работает, если вы игнорируете аргументы ключевых слов:
def manyArgs(*arg):
print "I was called with", len(arg), "arguments:", arg
>>> manyArgs(1)
I was called with 1 arguments: (1,)
>>> manyArgs(1, 2, 3)
I was called with 3 arguments: (1, 2, 3)
Как видите, Python предоставит вам один кортеж со всеми аргументами.
Для аргументов с ключевыми словами вам нужно принять их как отдельный фактический аргумент, как показано в ответе Скурмеделя.
Добавление к рассылке:
Вы также можете отправить несколько аргументов с ключом.
def myfunc(**kwargs):
# kwargs is a dictionary.
for k,v in kwargs.iteritems():
print "%s = %s" % (k, v)
myfunc(abc=123, efh=456)
# abc = 123
# efh = 456
И вы можете смешать два:
def myfunc2(*args, **kwargs):
for a in args:
print a
for k,v in kwargs.iteritems():
print "%s = %s" % (k, v)
myfunc2(1, 2, 3, banan=123)
# 1
# 2
# 3
# banan = 123
Они должны быть объявлены и вызваны в этом порядке, то есть подпись функции должна быть * args, ** kwargs и вызвана в этом порядке.
Если я могу, код Skurmedel для Python 2; чтобы адаптировать его к Python 3, измените его iteritems
на items
и добавьте круглые скобки для print
. Это может помешать начинающим, таким как я, наткнуться на: AttributeError: 'dict' object has no attribute 'iteritems'
и поиск в другом месте (например, у объекта '' dict 'нет атрибута' iteritems '' при попытке использовать NetworkX write_shp()), почему это происходит.
def myfunc(**kwargs):
for k,v in kwargs.items():
print("%s = %s" % (k, v))
myfunc(abc=123, efh=456)
# abc = 123
# efh = 456
а также:
def myfunc2(*args, **kwargs):
for a in args:
print(a)
for k,v in kwargs.items():
print("%s = %s" % (k, v))
myfunc2(1, 2, 3, banan=123)
# 1
# 2
# 3
# banan = 123
Добавление к другим отличным сообщениям.
Иногда вы не хотите указывать количество аргументов и для использования ключей для них (компилятор будет жаловаться, если один аргумент, переданный в словаре, не используется в методе).
def manyArgs1(args):
print args.a, args.b #note args.c is not used here
def manyArgs2(args):
print args.c #note args.b and .c are not used here
class Args: pass
args = Args()
args.a = 1
args.b = 2
args.c = 3
manyArgs1(args) #outputs 1 2
manyArgs2(args) #outputs 3
Затем вы можете делать такие вещи, как
myfuns = [manyArgs1, manyArgs2]
for fun in myfuns:
fun(args)
def f(dic):
if 'a' in dic:
print dic['a'],
pass
else: print 'None',
if 'b' in dic:
print dic['b'],
pass
else: print 'None',
if 'c' in dic:
print dic['c'],
pass
else: print 'None',
print
pass
f({})
f({'a':20,
'c':30})
f({'a':20,
'c':30,
'b':'red'})
____________
приведенный выше код выведет
None None None
20 None 30
20 red 30
Это так же хорошо, как передавать переменные аргументы с помощью словаря