webbrowser — 편리한 웹 브라우저 제어기¶
소스 코드: Lib/webbrowser.py
webbrowser 모듈은 웹 기반 문서를 사용자에게 표시할 수 있는 고수준 인터페이스를 제공합니다. 대부분의 상황에서, 이 모듈의 open() 함수를 호출하기만 하면 올바른 작업이 수행됩니다.
유닉스에서, X11에서는 그래픽 브라우저가 선호되지만, 그래픽 브라우저를 사용할 수 없거나 X11 디스플레이를 사용할 수 없으면 텍스트 모드 브라우저가 사용됩니다. 텍스트 모드 브라우저가 사용되면, 사용자가 브라우저를 종료할 때까지 호출하는 프로세스가 블록 됩니다.
환경 변수 BROWSER 가 존재하는 경우, 이는 플랫폼 기본값보다 먼저 시도할 브라우저의 os.pathsep 구분자로 구분된 목록으로 해석됩니다. 목록 부분이 %s 문자열을 포함하는 경우, 이는 인자 URL이 %s 로 대체되어 사용될 리터럴 브라우저 명령줄로 해석됩니다; 값이 이미 등록된 브라우저 중 하나를 참조하는 단일 단어인 경우, 이 브라우저가 검색 목록의 맨 앞에 추가됩니다; 부분이 %s 를 포함하지 않는 경우, 이는 단순히 실행할 브라우저 이름으로 해석됩니다. [1]
버전 3.14에서 변경: BROWSER 변수는 이제 플랫폼 기본값 목록을 재정렬하는 데에도 사용될 수 있습니다. 이는 플랫폼 기본값이 :envvar:`PATH`의 명령줄 도구를 참조하지 않는 macOS에서 특히 유용합니다.
유닉스가 아닌 플랫폼에서, 또는 유닉스에서 원격 브라우저를 사용할 수 있을 때, 제어하는 프로세스는 사용자가 브라우저를 완료할 때까지 기다리지 않고, 원격 브라우저가 디스플레이에 자체 창을 유지하도록 허용합니다. 유닉스에서 원격 브라우저를 사용할 수 없으면, 제어하는 프로세스가 새 브라우저를 시작하고 기다랍니다.
iOS에서는 BROWSER 환경 변수뿐만 아니라 autoraise, 브라우저 환경 설정, 새 탭/창 생성을 제어하는 어떠한 인자도 무시됩니다. 웹 페이지는 항상 사용자가 선호하는 브라우저의 새 탭에 열리며, 브라우저가 포그라운드로 가져와집니다. iOS에서 webbrowser 모듈을 사용하려면 ctypes 모듈이 필요합니다. ctypes`가 사용할 수 없으면, :func:.open`에 대한 호출이 실패할 것입니다.
명령줄 인터페이스¶
스크립트 webbrowser는 모듈의 명령 줄 인터페이스로 사용될 수 있습니다. 인자로 URL을 받아들입니다. 다음과 같은 선택적 매개 변수를 받아들입니다:
- -n, --new-window¶
가능하다면 새 브라우저 창에서 URL을 엽니다.
- -t, --new-tab¶
새 브라우저 탭에서 URL을 엽니다.
당연히, 이 옵션들은 상호 배타적입니다. 사용 예:
python -m webbrowser -t "https://www.python.org"
가용성: not WASI, not Android.
다음 예외가 정의됩니다:
- exception webbrowser.Error¶
브라우저 제어 에러가 일어날 때 발생하는 예외.
다음 함수가 정의됩니다:
- webbrowser.open(url, new=0, autoraise=True)¶
기본 브라우저를 사용하여 url을 표시합니다. new가 0이면, 가능하다면 같은 브라우저 창에서 url이 열립니다. new가 1이면, 가능하다면 새 브라우저 창이 열립니다. new가 2이면, 가능하다면 새 브라우저 페이지(“탭”)가 열립니다. autoraise가
True이면, 가능하다면 창을 올립니다(raise) (이것은 많은 창 관리자에서 이 변수의 설정과 관계없이 일어납니다).브라우저가 성공적으로 실행되면
True를 반환하고, 그렇지 않으면False를 반환합니다.일부 플랫폼에서, 이 함수를 사용하여 파일명을 여는 것은 동작하고 운영 체제의 연결된 프로그램이 시작될 수 있습니다. 하지만, 이것은 지원되지도 이식성 있지도 않습니다.
인자
url로 감사 이벤트(auditing event)webbrowser.open을 발생시킵니다.
- webbrowser.open_new(url)¶
가능하다면, 기본 브라우저의 새 창에서 url을 엽니다, 그렇지 않으면, 유일한 브라우저 창에서 url을 엽니다.
브라우저가 성공적으로 실행되면
True를 반환하고, 그렇지 않으면False를 반환합니다.
- webbrowser.open_new_tab(url)¶
가능하다면, 기본 브라우저의 새 페이지(“탭”)에서 url을 엽니다, 그렇지 않으면
open_new()와 동등합니다.브라우저가 성공적으로 실행되면
True를 반환하고, 그렇지 않으면False를 반환합니다.
- webbrowser.get(using=None)¶
브라우저 유형 using에 대한 제어기 객체를 반환합니다. using이
None이면, 호출자의 환경에 적합한 기본 브라우저을 위한 제어기 객체를 반환합니다.
- webbrowser.register(name, constructor, instance=None, *, preferred=False)¶
브라우저 유형 name을 등록합니다. 일단 브라우저 유형이 등록되면,
get()함수는 해당 브라우저 유형에 대한 제어기를 반환할 수 있습니다. instance가 제공되지 않거나,None이면, 필요할 때 constructor가 매개 변수 없이 호출되어 인스턴스를 만듭니다. instance가 제공되면, constructor는 절대로 호출되지 않으며,None일 수 있습니다.preferred를
True로 설정하면 이 브라우저를 인자 없이get()을 호출할 때 선호되는 결과가 되도록 합니다. 그렇지 않으면, 이 엔트리 포인트는BROWSER변수를 설정하거나 선언한 처리기의 이름과 일치하는 비어 있지 않은 인자로get()을 호출하려는 경우에만 유용합니다.버전 3.7에서 변경: preferred 키워드 전용 매개 변수가 추가되었습니다.
여러 가지 브라우저 유형이 미리 정의되어 있습니다. 이 표는 get() 함수로 전달될 수 있는 유형 이름과 제어기 클래스의 해당 인스턴스 화를 제공합니다, 모두 이 모듈에서 정의됩니다.
유형 이름 |
클래스 이름 |
노트 |
|---|---|---|
|
|
|
|
|
|
|
|
|
|
|
(1) |
|
|
(1) |
|
|
(1) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(2) |
|
|
(3) |
|
|
(3) |
|
|
(3) |
|
|
(3) |
|
|
|
|
|
|
|
|
|
|
|
(4) |
노트:
“Konqueror”는 유닉스용 KDE 데스크톱 환경의 파일 관리자이며, KDE가 실행 중일 때만 의미가 있습니다. 신뢰성 있게 KDE를 탐지하는 방법이 있다면 좋을 것입니다;
KDEDIR변수로는 충분하지 않습니다. KDE 2에서 konqueror 명령을 사용할 때조차도 “kfm”이라는 이름이 사용됨에 유의하십시오 — 구현이 Konqueror를 실행하기 위한 최상의 전략을 선택합니다.윈도우 플랫폼에서만.
맥 OS 에서만.
iOS 에서만.
Added in version 3.2: 새 MacOSXOSAScript 클래스가 추가되었으며 이전 MacOSX 클래스 대신 Mac에서 사용됩니다. 이는 OS 기본값으로 현재 설정되지 않은 브라우저를 여는 지원을 추가합니다.
Added in version 3.3: Chrome/Chromium에 대한 지원이 추가되었습니다.
버전 3.12에서 변경: 여러 구식 브라우저에 대한 지원이 제거되었습니다. 제거된 브라우저에는 Grail, Mosaic, Netscape, Galeon, Skipstone, Iceape 및 Firefox 버전 35 이하가 포함됩니다.
버전 3.13에서 변경: iOS에 대한 지원이 추가되었습니다.
Added in version 3.15: MacOS`가 :class:!MacOSXOSAScript`를 대체하는 클래스로 추가되었으며, osascript 대신 :program:`/usr/bin/open`을 통해 브라우저를 엽니다.
버전 3.15에서 폐지되었고, 버전 3.17에서 제거됩니다: MacOSXOSAScript`는 :class:!MacOS`가 선호되면서 사용이 중단되었습니다. osascript 대신 :program:`/usr/bin/open`을 사용하는 것은 보안 및 사용성 향상입니다. :program:`osascript`는 범용 스크립팅 인터프리터로서 오용될 가능성 때문에 관리되는 시스템에서 차단될 수 있습니다.
여기 몇 가지 간단한 예제가 있습니다:
url = 'https://docs.python.org/'
# 브라우저 창이 이미 열려 있으면, 새 탭에 URL을 엽니다.
webbrowser.open_new_tab(url)
# 새 창에 URL을 엽니다, 가능하다면 창을 올립니다.
webbrowser.open_new(url)
브라우저 제어기 객체¶
브라우저 컨트롤러는 name 속성과 다음 세 가지 메서드를 제공하며, 이는 모듈 수준의 편리한 함수들을 병행합니다:
- controller.name¶
브라우저에 대한 시스템 종속적 이름입니다.
- controller.open(url, new=0, autoraise=True)¶
이 제어기가 처리하는 브라우저를 사용하여 url을 표시합니다. new가 1이면, 가능하다면 새 브라우저 창이 열립니다. new가 2이면, 가능하다면 새 브라우저 페이지(“탭”)가 열립니다.
- controller.open_new(url)¶
가능하다면, 이 제어기가 처리하는 브라우저의 새 창에 url을 엽니다, 그렇지 않으면, 유일한 브라우저 창에 url을 엽니다. 별칭
open_new().
- controller.open_new_tab(url)¶
가능하다면, 이 제어기가 처리하는 브라우저의 새 페이지(“탭”)에 url을 엽니다, 그렇지 않으면
open_new()와 동등합니다.
각주