在Python中创建命令行界面的优秀方式

开发 后端
如果我想将输出记录到文本文件中,该怎么办?作为一个用户,您可以创建一个命令行界面来提供这些问题的解决方案。

我们先给大家介绍什么是命令行界面(CLI):

命令行界面或命令语言解释器,也称为命令行用户界面、控制台用户界面和字符用户界面,是一种与计算机程序交互的方式,用户以连续的文本行形式向程序发出命令。

通过创建命令行界面(CLI),可以使程序功能强大并具有交互性。CLI允许您接受命令行参数(操作系统命令行中程序名称后面的信息),以便向程序添加其他特性,使代码易于使用和灵活。根据程序的不同,这些参数可用于添加其他特性,如查看帮助文档、指定输出文件或启用测试特性,这些特性在正常使用时可能会出现问题。

[[329645]]

当我们刚开始用Python编程时,我们大多数只收集用户输入,交互方式是这样的:

  1. def main(): 
  2.     first = input(“Enter your first name:”) 
  3.     last = input(“Enter your last name:”) 
  4.     print(first + ' ' + last) 

虽然这段代码对于简单的脚本来说很好,但是这段代码不够灵活。当用户运行这个程序时,它们被限制为一组定义的规则。例如,如果我想将输出记录到文本文件中,该怎么办?作为一个用户,您可以创建一个命令行界面来提供这些问题的解决方案。

在Python中创建命令行界面的<span><span><span><i style=最佳方式" src="http://p3.pstatp.com/large/pgc-image/5b4f9a79a6624f63b433053d0c17c16c" _fcksavedurl="http://p3.pstatp.com/large/pgc-image/5b4f9a79a6624f63b433053d0c17c16c" _fcksavedurl="http://p3.pstatp.com/large/pgc-image/5b4f9a79a6624f63b433053d0c17c16c" width="640" height="387">

重要的注意事项

在创建CLI时,重要的是要考虑以下几点:

  • 必需参数:为了程序的运行,哪些参数是绝对必需的?
  • 文档:写出每个选项和参数的函数是很重要的,这样新用户就可以知道你的程序是如何工作的。
  • 处理错误情况:让用户确切地知道哪里出了问题
  • 运行时状态:如果任务没有立即完成,您应该打印出当前的进度

使用argparse读取参数

Argparse是一个用于解析命令行参数的Python标准库模块。作为程序员,您可以定义要接受的参数,而argparse将知道如何从sys中解析这些参数。当用户给程序提供无效参数时,Argparse还会自动生成帮助和使用消息,并输出错误。它使用起来非常简单,并且可以很容易地编写直观的CLI。

首先,创建一个名为test_cl .py的新文件,导入模块并初始化一个新的解析器:

  1. import argparse 
  2. parser = argparse.ArgumentParser() 
  3. parser.parse_args() 

现在使用--help选项运行代码:

  1. python3 test_cli.py --help 

你应该会收到一个很好的默认帮助信息,像这样:

  1. usage: test_cli.py [-h] 
  2. optional arguments: 
  3.     -h, --help  show this help message and exit 

祝贺您创建了第一个命令行界面!

现在让我们添加一个欢迎消息,简要地让您的用户知道这个程序是做什么的:

  1. welcome = "Practicing creating interactive command-line interfaces" 
  2. parser = argparse.ArgumentParser(description=welcome
  3. parser.parse_args() 

现在用-h标志运行程序。你应该可以看到你的欢迎信息。

添加参数

假设我们正在编写一个程序来爬一个网页。我们可能需要的一些参数是网页的域-domain或-d,日志输出到一个输出文件-ofile或-o的选项,可能还需要输出到控制台的特定行数-lines或-l的选项。对于这个例子,我们将域参数设置为必需的,而ofile和lines参数将是可选的。

通过使用.add_argument,我们可以很容易地向argparse CLI添加额外的参数,该参数允许我们定义使用细节。我们可以添加必要的参数——域,如:

  1. parser.add_argument('--domain', '-d', required=Truehelp='domain name of the website you want to scrape. i.e. “https://ahadsheriff.com"'

现在运行带有-h参数的程序,查看您编写的文档!

因为——domain是一个必需的参数,尝试运行不带任何标志的程序,您将收到以下消息:

  1. usage: test_cli.py [-h] --domain DOMAIN 
  2. test_cli.py: error: the following arguments are required: --domain/-d 

成功了!

现在使用argparse添加额外的参数。如果没有指定需要哪些参数,argparse将假定它们是可选的。你也可以设置参数的类型,对于——lines,我们取一个整数。您还可以为.add_argument设置其他有用的选项——比如action=

  1. parser.add_argument('--ofile', '-o', help='define output file to save results of stdout. i.e. "output.txt"'
  2. parser.add_argument('--lines', '-l', help='number of lines of output to print to the console"'type=int

现在测试您的代码,以确保一切正常运行。一种简单的方法是将参数的值存储为变量,然后打印这些值。

  1. args = parser.parse_args() 
  2. domain = args.domain 
  3. ofile = args.ofile 
  4. lines = args.lines 
  5. print("domain:", domain) 
  6. print("output file:", ofile) 
  7. print("lines:", lines) 

原文:

https://medium.com/@ahadsheriff/the-best-way-to-make-command-line-interfaces-in-python-e00e8b9d10c9

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2013-09-13 09:05:49

软件定义网络SDN

2021-07-12 14:53:27

LinuxGmail电子邮件

2010-03-24 14:08:10

CentOS命令行

2017-12-19 06:39:06

命令行界面CLIIT

2022-08-01 08:30:26

Python命令行

2023-03-01 11:35:45

2009-07-15 17:10:26

Jython解析命令行

2022-10-25 13:01:36

Linux命令行空目录

2023-03-28 08:40:22

命令行JSON用法

2009-08-07 10:33:53

linux命令行乱码linux命令行解决方式

2009-09-25 11:40:37

ibmdw云计算

2019-08-27 08:00:10

OpenStack命令虚拟机

2010-03-10 17:23:37

Python 命令行参

2022-09-27 13:07:41

clickPython命令行

2020-03-31 08:30:00

ffsendFireFox SenLinux

2019-07-15 05:50:19

Linux命令行VirtualBox版

2018-07-12 16:22:45

Linux命令行文本颜色

2009-08-04 10:13:09

Linux命令行代理服务器设置Linux命令行界面

2019-07-12 14:00:55

xclipLinux命令行

2021-07-15 13:32:12

Linux生成密码
点赞
收藏

51CTO技术栈公众号