"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Python의 argparse 마스터하기: 초보자를 위한 종합 가이드

Python의 argparse 마스터하기: 초보자를 위한 종합 가이드

2024-09-16에 게시됨
검색:263

Mastering Python’s argparse: A Comprehensive Guide for Beginners

소개

Python의 argparse 모듈은 사용자 친화적인 명령줄 인터페이스를 구축하기 위한 강력한 도구입니다. 간단한 스크립트를 개발하든 복잡한 애플리케이션을 개발하든 관계없이 argparse를 효과적으로 사용하는 방법을 알면 프로그램의 유용성을 크게 향상시킬 수 있습니다. 이 게시물에서는 기본 인수 구문 분석부터 고급 기능 및 모범 사례에 이르기까지 argparse를 마스터하기 위해 알아야 할 모든 것을 안내해 드리겠습니다.


argparse란 무엇입니까?

argparse 모듈은 Python 스크립트에 전달된 명령줄 인수를 처리하는 간단한 방법을 제공합니다. 자동으로 도움말 메시지를 생성하고 유형 검사를 처리하며 선택적 인수와 위치 인수를 모두 처리할 수 있습니다.

argparse를 사용하는 이유는 무엇입니까?

  • 자동 도움말 메시지: 사용자는 --help 옵션을 사용하여 프로그램 실행 방법을 쉽게 이해할 수 있습니다.
  • 유형 검사: 입력이 유효한지 확인할 수 있습니다(예: 예상되는 정수).
  • 읽기 가능한 명령줄 인터페이스: 스크립트를 더욱 전문적이고 사용자 친화적으로 만듭니다.

기본부터 시작해보세요!


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를 사용할 때 고려해야 할 몇 가지 모범 사례입니다.

  1. 항상 도움말 메시지 제공: add_argument의 도움말 인수를 사용하여 각 옵션의 기능을 설명합니다.
  2. 합리적인 기본값 사용: 모든 인수를 요구하지 않고도 원활한 실행을 보장하기 위해 적절한 경우 기본값을 제공합니다.
  3. 입력 유효성 검사: 선택 사항과 유형을 사용하여 사용자가 유효한 입력을 제공하는지 확인합니다.
  4. 단순하게 유지하세요: 꼭 필요한 경우가 아니면 너무 많은 인수로 스크립트를 오버로드하지 마세요.
  5. 명령 구조화: 복잡한 도구의 경우 하위 파서를 사용하여 다양한 명령을 논리적으로 분리합니다.

결론

argparse 모듈은 전문적이고 사용자 친화적인 Python 스크립트를 작성하는 데 필수적입니다. 위치 및 선택적 인수, 유형 검사, 하위 파서 등의 기능을 활용하여 직관적이고 강력한 명령줄 인터페이스를 만들 수 있습니다.

다음번에 Python 스크립트를 작성할 때 argparse를 사용하여 더 유연하고 접근 가능하게 만드는 것을 고려해 보세요. 즐거운 코딩하세요!


궁금한 점이나 제안 사항이 있으면 언제든지 문의해 주세요. 저와 연결하세요:

  • 링크드인
  • GitHub
릴리스 선언문 이 기사는 https://dev.to/usooldatascience/mastering-pythons-argparse-a-comprehensive-guide-for-beginners-48fn?1에 복제되어 있습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다. 그것
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3