A Python library that provides a decorator to automatically retrieve and process the argument names of a function when it's called. This can be useful for tasks like debugging, logging, or other custom operations.
Install argument-names via pip:
pip install argument-names
This example demonstrates how to utilize the argument_names decorator to log the names of the arguments passed to a function:
from argument_names import argument_names
@argument_names(function=lambda *args: print("Received arguments:", *args))
def process_data(_1, _2, _3):
pass
# Example invocation
name = "Alice"
age = 30
occupation = "Engineer"
# Calling the process_data function with the specified arguments
process_data(name, age, occupation) # Received arguments: name age occupation
process_data(occupation, age, age) # Received arguments: occupation age age
from argument_names import argument_names
@argument_names(function=lambda *args: print("".join(args)))
def foo(*args):
pass
h = None
e = 1
l = 9
o = 3
w = True
r = 3.14
d = 600
_ = 0.03
foo(h, e, l, l, o, _, w, o, r, l, d) # hello_world
-
The library requires you to provide named variables as arguments when calling the decorated function. Direct values, literals, or function calls will not work as expected.
For example, calling
process_data("Alice", 30, "Engineer")
would not work properly because the arguments are passed as values, not named variables. You must use named arguments like in the exampleprocess_data(name, age, occupation)
.
This project is licensed under the MIT License. See the LICENSE file for more details.