Pass a list to a function to act as multiple arguments
--------------------------------------------------
Hire the world's top talent on demand or became one of them at Toptal: https://topt.al/25cXVn
and get $2,000 discount on your first invoice
--------------------------------------------------
Music by Eric Matyas
https://www.soundimage.org
Track title: Puzzle Game 2 Looping
--
Chapters
00:00 Pass A List To A Function To Act As Multiple Arguments
00:25 Accepted Answer Score 367
00:38 Answer 2 Score 51
01:10 Answer 3 Score 20
01:26 Thank you
--
Full question
https://stackoverflow.com/questions/3480...
--
Content licensed under CC BY-SA
https://meta.stackexchange.com/help/lice...
--
Tags
#python #list #parameterpassing
#avk47
Hire the world's top talent on demand or became one of them at Toptal: https://topt.al/25cXVn
and get $2,000 discount on your first invoice
--------------------------------------------------
Music by Eric Matyas
https://www.soundimage.org
Track title: Puzzle Game 2 Looping
--
Chapters
00:00 Pass A List To A Function To Act As Multiple Arguments
00:25 Accepted Answer Score 367
00:38 Answer 2 Score 51
01:10 Answer 3 Score 20
01:26 Thank you
--
Full question
https://stackoverflow.com/questions/3480...
--
Content licensed under CC BY-SA
https://meta.stackexchange.com/help/lice...
--
Tags
#python #list #parameterpassing
#avk47
ACCEPTED ANSWER
Score 367
function_that_needs_strings(*my_list) # works!
You can read all about it here: Unpacking Argument Lists - The Python Tutorial
ANSWER 2
Score 51
Yes, you can use the *args (splat) syntax:
function_that_needs_strings(*my_list)
where my_list can be any iterable; Python will loop over the given object and use each element as a separate argument to the function.
See the call expression documentation.
There is a keyword-parameter equivalent as well, using two stars:
kwargs = {'foo': 'bar', 'spam': 'ham'}
f(**kwargs)
and there is equivalent syntax for specifying catch-all arguments in a function signature:
def func(*args, **kw):
# args now holds positional arguments, kw keyword arguments
ANSWER 3
Score 20
Since Python 3.5 you can unpack unlimited amount of lists.
PEP 448 - Additional Unpacking Generalizations
So this will work:
a = ['1', '2', '3', '4']
b = ['5', '6']
function_that_needs_strings(*a, *b)