소스 코드 링크
아아아아아아
/
objwatch
?️ ObjWatch는 객체 속성과 메소드 호출을 추적하고 모니터링하는 Python 라이브러리입니다.
ObjWatch
[ 한국어 | 중국어 ]
개요
ObjWatch는 복잡한 프로젝트의 디버깅 및 모니터링을 간소화하도록 설계된 강력한 Python 라이브러리입니다. ObjWatch는 객체 속성 및 메소드 호출에 대한 실시간 추적을 제공함으로써 개발자가 코드베이스에 대한 더 깊은 통찰력을 얻을 수 있도록 지원하여 문제 식별, 성능 최적화 및 전반적인 코드 품질 향상을 촉진합니다.
ObjWatch는 애플리케이션 성능에 영향을 미칠 수 있습니다. 디버깅 환경에서만 사용을 권장합니다.
특징
-
중첩 구조 추적: 명확한 계층적 로깅을 통해 중첩 함수 호출과 개체 상호 작용을 시각화하고 모니터링합니다.
-
향상된 로깅 지원: 간단하고 세부적인 형식에 대한 지원을 포함하여 구조화되고 사용자 정의 가능한 로그 출력을 위해 Python의 내장 로깅 모듈을 활용합니다. 또한 로거가 외부 라이브러리에 의해 비활성화되거나 제거된 경우에도 로그가 캡처되도록 하려면 level="force"를 설정할 수 있습니다. level이 "force"로 설정되면 ObjWatch는 표준 로깅 처리기를 우회하고 print()를 사용하여…
현재 디버깅 문제
복잡한 프로젝트를 읽고 디버깅할 때 최대 12개의 레이어가 포함된 중첩 호출이 발생하는 경우가 많아 실행 순서를 결정하기가 어렵습니다. 가장 실망스러운 점은 다중 프로세스 환경에서 디버깅하는 것입니다. 단일 프로세스를 디버깅하면 다른 프로세스가 대기하고 시간 초과되는 경우가 많아 디버깅 프로그램을 지속적으로 다시 시작해야 합니다. print 문을 사용하면 함수 호출이 누락되는 경우가 많아 시간이 많이 걸리고 힘든 일이 됩니다. 현재 단순성과 포괄성을 겸비한 디버깅 라이브러리가 없어서 주말을 들여 이 문제점을 해결하는 도구를 개발했습니다.
ObjWatch란 무엇입니까?
ObjWatch는 복잡한 프로젝트의 디버깅 및 모니터링을 단순화하도록 특별히 설계되었습니다. 객체 속성 및 메소드 호출에 대한 실시간 추적을 제공하고 개발자가 코드베이스에 대해 더 깊은 통찰력을 얻을 수 있도록 사용자 정의 후크를 허용합니다.
빠른 사용 예
pip install objwatch를 사용하여 직접 설치할 수 있습니다. 시연을 위해 소스 코드를 복제해야 합니다.
git clone https://github.com/aeeeeeep/objwatch cd objwatch pip install . python3 examples/example_usage.py
위 코드를 실행하면 다음과 같은 통화 정보가 생성됩니다.
[2025-01-04 19:15:13] [DEBUG] objwatch: Processed targets: >>>>>>>>>> examples/example_usage.py None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.increment 10 [2025-01-04 19:15:13] [DEBUG] objwatch: | | upd SampleClass.value 10 -> 11 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.increment -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.increment 12 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.increment -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.increment 13 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.increment -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.increment 14 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.increment -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.increment 15 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.increment -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.decrement 14 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.decrement -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.decrement 13 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.decrement -> None [2025-01-04 19:15:13] [DEBUG] objwatch: | run SampleClass.decrement 12 [2025-01-04 19:15:13] [DEBUG] objwatch: | end SampleClass.decrement -> None [2025-01-04 19:15:13] [DEBUG] objwatch: end main -> None [2025-01-04 19:15:13] [INFO] objwatch: Stopping ObjWatch tracing. [2025-01-04 19:15:13] [INFO] objwatch: Stopping tracing.
코드에서 가장 중요한 부분은 다음과 같습니다.
# Using as a Context Manager with Detailed Logging with objwatch.ObjWatch(['examples/example_usage.py']): main() # Using the API with Simple Logging obj_watch = objwatch.watch(['examples/example_usage.py']) main() obj_watch.stop()
컨텍스트 관리자와 API 호출을 통해 도구를 사용할 수 있습니다. 예제에서는 예제/example_usage.py 파일에 대한 추적을 지정합니다. 즉, 예제/example_usage.py 내의 모든 함수, 메서드 또는 변수가 도구에 의해 기록됩니다. 이 명확한 계층적 로깅은 중첩된 함수 호출과 개체 상호 작용을 시각화하고 모니터링하는 데 도움이 됩니다. 인쇄된 로그에는 다음과 같은 실행 유형이 포함됩니다.
- run: 함수 또는 클래스 메서드 실행의 시작을 나타냅니다.
- end: 함수 또는 클래스 메서드 실행의 끝을 나타냅니다.
- upd: 새 변수 생성을 나타냅니다.
- apd: 목록, 세트 또는 사전과 같은 데이터 구조에 요소가 추가됨을 나타냅니다.
- pop: 목록, 세트 또는 사전과 같은 데이터 구조에서 요소 제거를 표시합니다.
예제는 비교적 간단하지만 이 기능은 대규모 프로젝트를 실행하는 데 매우 유용합니다.
전반적인 특징
ObjWatch는 다음 인터페이스를 제공합니다.
- 대상(목록): 모니터링할 파일 또는 모듈입니다.
- 제외_대상(목록, 선택): 모니터링에서 제외할 파일 또는 모듈.
- 순위(목록, 선택 사항): torch.distributed를 사용할 때 추적할 GPU 순위.
- 출력(str, 선택): 로그 작성을 위한 파일 경로
- output_xml(str, 선택 사항): 구조화된 로그를 작성하기 위한 XML 파일의 경로입니다. 지정하면 추적 정보가 중첩된 XML 형식으로 저장되어 쉽게 찾아보고 분석할 수 있습니다.
- level (str, 선택사항): 로깅 수준(예: login.DEBUG, login.INFO, force 등).
- simple(bool, 선택 사항): "DEBUG: {msg}" 형식으로 단순 로깅 모드를 활성화합니다.
- 래퍼(FunctionWrapper, 선택 사항): 추적 및 로깅 기능을 확장하기 위한 사용자 정의 래퍼입니다.
- with_locals(부울, 선택 사항): 실행 중에 함수 내에서 지역 변수의 추적 및 로깅을 활성화합니다.
- with_module_path(부울, 선택 사항): 로그의 함수 이름 앞에 모듈 경로를 추가할지 여부를 제어합니다.
주요 기능: 사용자 정의 래퍼 확장
ObjWatch는 FunctionWrapper 추상 기본 클래스를 제공하므로 사용자는 사용자 정의 래퍼를 생성하여 라이브러리의 추적 및 로깅 기능을 확장하고 사용자 정의할 수 있습니다. FunctionWrapper를 상속함으로써 개발자는 특정 프로젝트 요구 사항에 맞는 사용자 정의 동작을 구현할 수 있습니다. 이러한 동작은 함수 호출 및 반환 중에 실행되어 보다 전문적인 모니터링을 제공합니다.
FunctionWrapper 클래스
FunctionWrapper 클래스는 구현해야 하는 두 가지 핵심 메서드를 정의합니다.
- wrap_call(self, func_name: str, 프레임: FrameType) -> 문자열:
이 메서드는 함수 호출 시작 시 호출됩니다. 함수 이름과 지역 변수 및 호출 스택을 포함한 실행 컨텍스트가 포함된 현재 프레임 개체를 수신합니다. 함수가 실행되기 전에 정보를 추출, 기록, 수정하려면 이 방법을 구현하세요.
- wrap_return(self, func_name: str, result: Any) -> 문자열:
이 메서드는 함수 반환 시 호출됩니다. 함수 이름과 함수가 반환한 결과를 받습니다. 함수 실행이 완료된 후 정보를 기록, 분석 또는 변경하려면 이 방법을 사용하세요.
- wrap_upd(self, old_value: Any, current_value: Any) -> 튜플[str, str]:
이 메서드는 변수가 업데이트될 때 트리거되어 이전 값과 현재 값을 받습니다. 변수 변경 사항을 기록하는 데 사용할 수 있으므로 변수 상태 전환을 추적하고 디버깅할 수 있습니다.
프레임 객체에 대한 자세한 내용은 공식 Python 설명서를 참조하세요.
TensorShapeLogger
이것은 내 사용 시나리오를 기반으로 구현한 사용자 정의 래퍼의 예입니다. 코드는 objwatch/wrappers.py 파일에 있습니다. 이 래퍼는 지정된 모듈 내의 모든 함수 메서드 호출에서 입력 및 출력의 텐서 형태와 변수 상태를 자동으로 기록합니다. 이는 복잡한 분산 프레임워크의 실행 로직을 이해하는 데 매우 유용합니다.
git clone https://github.com/aeeeeeep/objwatch cd objwatch pip install . python3 examples/example_usage.py
딥 러닝 프로젝트에서는 텐서의 모양과 크기가 중요합니다. 작은 차원 오류로 인해 전체 모델이 올바르게 훈련되거나 예측되지 않을 수 있습니다. 각 텐서의 형태를 수동으로 확인하는 것은 지루하고 오류가 발생하기 쉽습니다. TensorShapeLogger는 텐서 형태 기록을 자동화하여 개발자가 다음을 수행하도록 돕습니다.
- 치수 불일치 문제를 신속하게 식별: 형상 정보를 자동으로 기록하여 치수 오류를 신속하게 감지하고 수정합니다.
- 모델 아키텍처 최적화: 텐서 형태의 변화를 추적하여 네트워크 구조를 최적화하여 모델 성능을 향상시킵니다.
- 디버깅 효율성 향상: 텐서 형태를 수동으로 확인하는 데 소요되는 시간을 줄여 핵심 모델 개발에 집중할 수 있습니다.
사용자 정의 래퍼 사용 예
tests/test_torch_train.py 파일을 참고하는 것이 좋습니다. 이 파일에는 모니터링 및 로깅을 위해 ObjWatch를 통합하는 방법을 보여주는 PyTorch 교육 프로세스의 전체 예가 포함되어 있습니다.
메모
⚠️ 성능 경고
ObjWatch는 디버깅 환경에서 사용될 때 프로그램 성능에 영향을 미칠 수 있습니다. 따라서 디버깅 및 개발 단계에서만 사용하는 것을 권장합니다.
이 글은 초기 작성일 뿐입니다. 시간이 지나면 더 추가할 계획입니다. 유용하다고 생각하시면 별점을 주세요.
라이브러리는 계속 업데이트되고 있습니다. 질문이나 제안 사항이 있으면 댓글을 남기거나 저장소에서 이슈를 열어주세요.
위 내용은 디버깅 구세주! 복잡한 Python 프로젝트에서 효율적인 코드 이해 및 디버깅을 위해 ObjWatch 활용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사에서는 HTML을 구문 분석하기 위해 파이썬 라이브러리 인 아름다운 수프를 사용하는 방법을 설명합니다. 데이터 추출, 다양한 HTML 구조 및 오류 처리 및 대안 (SEL과 같은 Find (), find_all (), select () 및 get_text ()와 같은 일반적인 방법을 자세히 설명합니다.

Python의 통계 모듈은 강력한 데이터 통계 분석 기능을 제공하여 생물 통계 및 비즈니스 분석과 같은 데이터의 전반적인 특성을 빠르게 이해할 수 있도록 도와줍니다. 데이터 포인트를 하나씩 보는 대신 평균 또는 분산과 같은 통계를보고 무시할 수있는 원래 데이터에서 트렌드와 기능을 발견하고 대형 데이터 세트를보다 쉽고 효과적으로 비교하십시오. 이 튜토리얼은 평균을 계산하고 데이터 세트의 분산 정도를 측정하는 방법을 설명합니다. 달리 명시되지 않는 한,이 모듈의 모든 함수는 단순히 평균을 합산하는 대신 평균 () 함수의 계산을 지원합니다. 부동 소수점 번호도 사용할 수 있습니다. 무작위로 가져옵니다 수입 통계 Fracti에서

파이썬 객체의 직렬화 및 사막화는 사소한 프로그램의 주요 측면입니다. 무언가를 Python 파일에 저장하면 구성 파일을 읽거나 HTTP 요청에 응답하는 경우 객체 직렬화 및 사태화를 수행합니다. 어떤 의미에서, 직렬화와 사제화는 세계에서 가장 지루한 것들입니다. 이 모든 형식과 프로토콜에 대해 누가 걱정합니까? 일부 파이썬 객체를 지속하거나 스트리밍하여 나중에 완전히 검색하려고합니다. 이것은 세상을 개념적 차원에서 볼 수있는 좋은 방법입니다. 그러나 실제 수준에서 선택한 직렬화 체계, 형식 또는 프로토콜은 속도, 보안, 유지 보수 상태 및 프로그램의 기타 측면을 결정할 수 있습니다.

이 기사는 딥 러닝을 위해 텐서 플로와 Pytorch를 비교합니다. 데이터 준비, 모델 구축, 교육, 평가 및 배포와 관련된 단계에 대해 자세히 설명합니다. 프레임 워크, 특히 계산 포도와 관련하여 주요 차이점

Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.

이 튜토리얼은 간단한 나무 탐색을 넘어서 DOM 조작에 중점을 둔 아름다운 수프에 대한 이전 소개를 바탕으로합니다. HTML 구조를 수정하기위한 효율적인 검색 방법과 기술을 탐색하겠습니다. 일반적인 DOM 검색 방법 중 하나는 EX입니다

이 기사는 Python 개발자가 CLIS (Command-Line Interfaces) 구축을 안내합니다. Typer, Click 및 Argparse와 같은 라이브러리를 사용하여 입력/출력 처리를 강조하고 CLI 유용성을 향상시키기 위해 사용자 친화적 인 디자인 패턴을 홍보하는 세부 정보.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
