Аналогично использованию 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
Это так же хорошо, как передавать переменные аргументы с помощью словаря