Python의 argparse 모듈은 사용자 친화적인 명령줄 인터페이스를 구축하기 위한 강력한 도구입니다. 간단한 스크립트를 개발하든 복잡한 애플리케이션을 개발하든 관계없이 argparse를 효과적으로 사용하는 방법을 알면 프로그램의 유용성을 크게 향상시킬 수 있습니다. 이 게시물에서는 기본 인수 구문 분석부터 고급 기능 및 모범 사례에 이르기까지 argparse를 마스터하기 위해 알아야 할 모든 것을 안내해 드리겠습니다.
argparse 모듈은 Python 스크립트에 전달된 명령줄 인수를 처리하는 간단한 방법을 제공합니다. 자동으로 도움말 메시지를 생성하고 유형 검사를 처리하며 선택적 인수와 위치 인수를 모두 처리할 수 있습니다.
argparse를 사용하는 이유는 무엇입니까?
기본부터 시작해보세요!
argparse 사용을 시작하려면 먼저 모듈을 가져오고 ArgumentParser 개체를 만들어야 합니다.
import argparse parser = argparse.ArgumentParser(description="Demo script for argparse.")
여기서 설명 인수는 선택사항이며 스크립트의 목적을 설명하는 데 도움이 됩니다. 사용자가 --help 명령을 실행할 때 표시됩니다.
위치 인수는 argparse에서 가장 기본적인 인수 유형입니다. 이는 필수이며 명령에 올바른 순서로 나타나야 합니다.
parser.add_argument("name", help="Your name") args = parser.parse_args() print(f"Hello, {args.name}!")
스크립트 실행:
$ python script.py Alice Hello, Alice!
name 인수를 제공하지 않으면 argparse에서 오류가 발생합니다.
$ python script.py usage: script.py [-h] name script.py: error: the following arguments are required: name
선택적 인수는 이름에서 알 수 있듯이 필수는 아닙니다. 위치 인수와 구별하기 위해 일반적으로 하나 또는 두 개의 대시(- 또는 --)로 시작합니다.
parser.add_argument("-g", "--greeting", help="Custom greeting message", default="Hello") args = parser.parse_args() print(f"{args.greeting}, {args.name}!")
스크립트 실행:
$ python script.py Alice --greeting Hi Hi, Alice!
기본 인수는 사용자가 다음 옵션을 제공하지 않는 경우 기본값이 사용되도록 보장합니다.
$ python script.py Alice Hello, Alice!
기본적으로 모든 인수는 문자열로 처리됩니다. 그러나 원하는 인수 유형을 지정할 수 있습니다. 예를 들어 정수가 필요한 경우:
parser.add_argument("age", type=int, help="Your age") args = parser.parse_args() print(f"{args.name} is {args.age} years old.")
스크립트 실행:
$ python script.py Alice 25 Alice is 25 years old.
잘못된 유형(예: 정수가 필요한 문자열)을 제공하면 argparse가 자동으로 오류를 표시합니다.
$ python script.py Alice twenty-five usage: script.py [-h] name age script.py: error: argument age: invalid int value: 'twenty-five'
플래그 인수는 특정 기능을 활성화하거나 비활성화하는 데 유용합니다. 이는 값을 취하지 않지만 스위치 역할을 합니다. 플래그를 생성하려면 action="store_true" 옵션을 사용하세요.
parser.add_argument("-v", "--verbose", action="store_true", help="Enable verbose mode") args = parser.parse_args() if args.verbose: print("Verbose mode is on.")
스크립트 실행:
$ python script.py Alice -v Verbose mode is on.
플래그를 제공하지 않으면 기본값인 False가 사용됩니다.
$ python script.py Alice
argparse를 사용하면 동일한 인수에 대해 짧은 옵션 이름과 긴 옵션 이름을 모두 정의할 수 있습니다. 예를 들어:
parser.add_argument("-g", "--greeting", help="Custom greeting message")
짧은 버전(-g) 또는 긴 버전(--greeting)을 사용할 수 있습니다.
$ python script.py Alice -g Hi Hi, Alice!
$ python script.py Alice --greeting Hi Hi, Alice!
경우에 따라 선택적 인수에 대한 기본값을 정의할 수 있습니다. 이렇게 하면 인수가 누락된 경우에도 프로그램이 올바르게 작동할 수 있습니다.
parser.add_argument("-g", "--greeting", default="Hello", help="Greeting message") args = parser.parse_args() print(f"{args.greeting}, {args.name}!")
nargs를 사용하여 여러 값을 허용하는 인수를 지정할 수도 있습니다. 예를 들어, 여러 파일 이름을 허용하려면:
parser.add_argument("files", nargs=" ", help="List of file names") args = parser.parse_args() print(f"Files to process: {args.files}")
스크립트 실행:
$ python script.py file1.txt file2.txt file3.txt Files to process: ['file1.txt', 'file2.txt', 'file3.txt']
선택 옵션을 사용하여 인수의 가능한 값을 제한할 수 있습니다.
parser.add_argument("--format", choices=["json", "xml"], help="Output format") args = parser.parse_args() print(f"Output format: {args.format}")
스크립트 실행:
$ python script.py Alice --format json Output format: json
사용자가 잘못된 선택을 제공하면 argparse에서 오류가 발생합니다.
$ python script.py Alice --format csv usage: script.py [-h] [--format {json,xml}] name script.py: error: argument --format: invalid choice: 'csv' (choose from 'json', 'xml')
동일한 스크립트에서 위치 인수와 선택적 인수를 혼합하고 일치시킬 수 있습니다.
parser.add_argument("name", help="Your name") parser.add_argument("--greeting", help="Custom greeting", default="Hello") parser.add_argument("--verbose", action="store_true", help="Enable verbose output") args = parser.parse_args() if args.verbose: print(f"Running in verbose mode...") print(f"{args.greeting}, {args.name}!")
argparse의 가장 큰 장점 중 하나는 내장된 도움말 메시지 생성기입니다. 사용자가 -h 또는 --help 플래그를 사용하여 스크립트를 실행하면 argparse가 자동으로 인수와 해당 설명을 표시합니다.
$ python script.py -h usage: script.py [-h] [--greeting GREETING] [--verbose] name Demo script for argparse. positional arguments: name Your name optional arguments: -h, --help show this help message and exit --greeting GREETING Custom greeting --verbose Enable verbose output
스크립트에 여러 하위 명령(예: git commit, git push)이 있는 경우 하위 파서를 사용하여 처리할 수 있습니다.
parser = argparse.ArgumentParser(description="Git-like command-line tool") subparsers = parser.add_subparsers(dest="command") # Add "commit" subcommand commit_parser = subparsers.add_parser("commit", help="Record changes to the repository") commit_parser.add_argument("-m", "--message", help="Commit message", required=True) # Add "push" subcommand push_parser = subparsers.add_parser("push", help="Update remote refs") args = parser.parse_args() if args.command == "commit": print(f"Committing changes with message: {args.message}") elif args.command == "push": print("Pushing changes to remote repository.")
다음은 argparse를 사용할 때 고려해야 할 몇 가지 모범 사례입니다.
argparse 모듈은 전문적이고 사용자 친화적인 Python 스크립트를 작성하는 데 필수적입니다. 위치 및 선택적 인수, 유형 검사, 하위 파서 등의 기능을 활용하여 직관적이고 강력한 명령줄 인터페이스를 만들 수 있습니다.
다음번에 Python 스크립트를 작성할 때 argparse를 사용하여 더 유연하고 접근 가능하게 만드는 것을 고려해 보세요. 즐거운 코딩하세요!
궁금한 점이나 제안 사항이 있으면 언제든지 문의해 주세요. 저와 연결하세요:
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3