The argparse in PythonIn this article, we will learn the argparse module in Python. We will explore its working and functionalities. It is a very important topic for the fundamental developer, engineer, and computer scientist. As we all familiar, Python is popular for containing and rich library. If the developer writes the script for the command line, he/she is also required to pass the command-line argument that we can create using the argparse library. In this article, we will explore the following topics related to argparse.
Let's understand what is argparse is and how we can implement it. What is command line interface?The command-line interface is also known as the CLI, which interacts with a command-line script. Python provides many libraries that allow us to work with the CLI, but Python argparse is the most suitable library in the current scenario. How does the command line interface work?Before getting deep down into this topic, we need to understand how the command line interface works? So open the command line terminal and type the ls command to get the entire list of files available in the system. Output: face.png Favorites file1.txt file2.txt flower.jpg forest.jpg Gow-0.8.0.exe gradients.jpg hadoop-2.8.0 hadoop-2.8.0.tar.gz hello_fullstack highway.mp4 IBA_IOAPDATA innocentcat IntelGraphicsProfiles international-cricket-players-data.zip Iris.csv iris.zip java_error_in_pycharm_6408.log java_error_in_pycharm_6684.log jtp_logo.png linear_reg linear_reg.zip Links Local Settings main_image.jpg mario.png metastore_db MicrosoftEdgeBackups Music My Documents mycus 9c409ba1dd3f}.TMContainer00000000000000000001.regtrans-ms NTUSER.DAT{42939bbc-edb6-11ea-9c24-9c409ba1dd3f}.TMContainer00000000000000000002.regtrans-ms ntuser.ini PySpark DataFrame.ipynb PySpark RDD.ipynb PySpark SQL.ipynb PySpark UDF.ipynb tesseract-3.02.02-win32-lib-include-dirs tesseract-3.02.02-win32-lib-include-dirs.zip As we can see in the above output, the ls command returns many files that are available in the current directory. Now, we will run the ls command by adding option -l to the command line. Output: total 717704 drw-rw-rw- 2 DEVANSH SHARMA 0 0 2020-04-07 13:25 __pycache__ dr--r--r-- 2 DEVANSH SHARMA 0 0 2020-09-03 13:42 3D Objects drw-rw-rw- 2 DEVANSH SHARMA 0 0 2014-01-03 15:37 8235702-a50f7c449c41b6dc8eb87d8d393eeff62121b392 drw-rw-rw- 20 DEVANSH SHARMA 0 32768 2020-12-07 16:20 Anaconda3 drw-rw-rw- 5 DEVANSH SHARMA 0 0 2020-09-03 13:02 AppData drw-rw-rw- 2 DEVANSH SHARMA 0 8192 2021-02-11 21:39 Application Data -rw-rw-rw- 1 DEVANSH SHARMA 0 224 2019-11-13 14:38 array.mat -rw-rw-rw- 1 DEVANSH SHARMA 0 69548 2019-12-03 14:18 ballon.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 69548 2019-12-03 14:20 baloon.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 1857 2019-10-15 12:16 binary.png -rw-rw-rw- 1 DEVANSH SHARMA 0 5 2020-04-01 16:46 binfile.bin -rw-rw-rw- 1 DEVANSH SHARMA 0 13911 2019-10-16 11:52 blob.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 244879 2019-10-14 14:19 book1.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 10064 2020-04-07 16:35 calculation.py -rw-rw-rw- 1 DEVANSH SHARMA 0 23073 2019-12-06 15:30 calibresult.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 336 2019-11-29 15:11 cat.jpeg -rw-rw-rw- 1 DEVANSH SHARMA 0 0 2019-12-05 12:34 cat.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 13001 2019-10-13 17:22 cat_16x9.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 249726 2019-10-13 15:02 cat1.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 5633 2019-12-04 11:16 coin.jpg -rw-rw-rw- 1 DEVANSH SHARMA 0 8652 2019-12-04 11:23 coin1.png -rw-rw-rw- 1 DEVANSH SHARMA 0 59918 2020-03-02 11:22 comic.png dr--r--r-- 2 DEVANSH SHARMA 0 0 2020-09-03 13:42 Contacts What is argparse in Python?Python argparse is a command-line parsing module that is recommended to work with the command line argument. This module was released as a part of the standard library with Python on 20th February 2011. It is similar to the getopt module, but it is slightly hard to use and requires more code lines to perform the same task. However, the argparse module is the better replacement of the Python getopt and optparse module. It provides a few important features that are given below.
How to implement the argparse library to create a command-line interface?Let's see the following simple example to understand the working of the argparse module in Python. Example - In the following example, we create a simple Python program to perform the add operation using the argparse module. We will pass the argument through the command-line interface. We have imported the argparse module and created a simple parser that will use throughout the program. We have called the add_argument() method and pass two arguments - num1 and help. We have saved the above code in the file named code.py. To run this program, we open the command-line interface and run the above file. Command When we press enter, it will show the following output. Output: usage: code.py [-h] num1 num2 operation code.py: error: the following arguments are required: num1, num2, operation As we can see, it shows error because we didn't pass the required argument. Now, we will pass the optional argument - h which is basically used for help. Command It will show the following output. usage: code.py [-h] num1 num2 operation positional arguments: num1 first number num2 second number operation operation optional arguments: -h, --help show this help message and exit We get all the arguments list which we have defined in our Python program. Now, we will print both arguments and the operation by adding the following operation. When we execute the .parse_args(), we get a Namespace object containing a simple property of each input argument received from the command line. We print the argument to the console using the args variable. By default, it takes input as so we need to typecast into integer. To add these two numbers, we define the add operation in our code. C:\Users\DEVANSH SHARMA\PycharmProjects\Elasticsearch>python code.py 20 30 add 20 30 add The Result is : 50 Example - 1 Simple Calculator Program using argparse Output: Types of Argument in Command Line InterfaceThere are two arguments that we can add to the command-line interface.
Let's understand the both arguments. Positional Argument - Positional arguments are the types of argument that we use in command to operate. We pass the argument to the command and perform some operations. Their position defines by their function. That's why they are called a positional argument. By default, the positional arguments are treated as String, however we can typecast in other data types. In the previous example, we have used positional arguments to perform the add operation between the two numbers. Let's understand the following code. Example - 1 Output: We have passed 15 and it returned 1515 because argparse treated as string. We can correct this using the type attribute. Example - Output: Now, we get the desired result. Optional Argument - Optional Argument are not mandatory. We will not get the error if not passed to the script. These types of arguments are started with the - single dash or "--" double dash prefix. We need to call the .add_parse() to pass the optional arguments. Let's understand the following example. Example - When we run the above code without passing any arguments, it will show the following output. Output: As we can see in the above code, we ran the script without passing any optional argument and instead of returning error it returns none. The help message and data types for optional parameters are same as in positional parameters. Python argparse Positional ArgumentSometimes, we need the arguments that are mandatory to be passed in the script on execution. Let's see an example it not passed. Example - When we run the above code with the different parameter, it will show the following argument. Output: We can show the error if the argument is not passed in the command line terminal. Python argparse Positional Argument Default ValuesWe can provide the default value to a variable or argument using the argparse module. In the previous example, positional argument value is empty when not provided. Let's understand the following example. Example - Output: Using Short Name for Optional ArgumentPassing the many optional can make our Python script long. So we can assign the short name to the parameters as well. We can give the abbreviation name to parameters; it will help us to keep our Python script short. Let's understand the following example. Example - Output: C:\Users\DEVANSH SHARMA\PycharmProjects\Elasticsearch>python code.py -w Devansh Technical Writer. In the above code, we have assigned the short to both optional arguments. We can access it by using its short name. Combining Optional and Positional Arguments with argparseWe can combine both optional and position arguments using the argparse as follows. Let's understand the following example. Example - Output: C:\Users\DEVANSH SHARMA\PycharmProjects\Elasticsearch>python code.py Javatpoint -w Devansh You made it! Technical Writer. We have passed both types of argument to the command-line and get the above output. ConclusionSo far, we have discussed all-important concept of the argparse Python module. We have learned how we can create them and how we can use them through the command-line interface. We have also learned what the argparse module is and why it is important to write command-line scripts in Python. This module helps us create self-explanatory programs and provide users with a means of interacting with our application. Next TopicPython tqdm Module |