목차
정답
백엔드 개발 파이썬 튜토리얼 LibHaru의 Python 바인딩을 Python 3.9(64비트)로 업데이트해 본 사람이 있나요?

LibHaru의 Python 바인딩을 Python 3.9(64비트)로 업데이트해 본 사람이 있나요?

Feb 09, 2024 am 08:54 AM
overflow

有人尝试将 LibHaru 的 Python 绑定更新为 Python 3.9(64 位)吗?

질문 내용

저는 Python 3.9, 64비트를 실행 중이고 VS 2022를 사용하여 libharu와 libpng를 포함한 일부 확장을 DLL로 컴파일했습니다. VS 런타임 DLL(libhpdf)을 찾기 위해 최소한의 코드 조정을 추가한 후 DLL을 Python에 로드할 수 있습니다. dll 종속성이 있고 작동하는 것 같습니다(번들에 5개의 .py 파일만 있음). 진행 상황을 추적하기 위해 PTRACE가 활성화된 DLL을 구축했습니다. C 데모도 이 DLL을 사용하여 동적으로 구축되었으며 모두 작동하여 PDF를 생성합니다.

바인딩에 포함된 Python 데모 예제 arc_demo.py를 실행하려고 합니다. 동일한 PDF 파일을 생성하고 싶습니다

문서에 다음 줄을 추가하기 전까지는 모든 것이 잘 작동한다고 말할 수 있습니다. pdf = HPDF_New (error_handler, NULL) 예제의 컴파일된 C 버전을 사용하여 얻은 추적과 유사한 출력입니다.

하지만... var "pdf"는 HP_AddPage()가 기대하는 것과 다릅니다. 왜냐하면 다음 호출이 실행될 때 페이지가 추가되기 때문입니다. page = HPDF_AddPage (pdf) 나는 이것을 발견했습니다 : **ctypes.ArgumentError:参数 1:<class 'OverflowError'>:int 太长,无法转换**

이것은 32비트로만 빌드되고 테스트되는 원래 바인딩과 관련이 있을 수 있다고 생각합니다. 또 다른 용의자는 포팅된 ctypes입니다.

이제는 주로 hpdf.py 바인딩을 수정하고 있습니다. 현재 Python과 DLL 간 상호 통신에 어려움을 겪고 있으며 ctypes가 예상대로 처리하는지 확인하고 있습니다. byref ,将 *pdf * 转换为 c_void_p를 사용하면...운이 없습니다. 호출이 ref(c_void_p(pdf))를 통해 이루어지면 오류는 제거되지만 HPPDF_Doc 구조의 내용에 제대로 액세스할 수 없습니다

제안사항이 있나요? 혹시 도와주실 수 있나요? C 기반 DLL을 사용하여 Python을 디버깅하는 비교 접근 방식은 무엇입니까?

감사합니다. 이그나시오

PS: 결국 Haru PDF 내부를 위한 수업이 작성될 예정입니다. 하지만 이런 일은 오류 없이 Python 예제를 실행할 수 있게 된 후에 발생합니다.


정답


if/python/hpdf.py中的ctypes接口没有为所有函数定义.argtypes。对于 64 位句柄和指针来说,为每个函数定义正确的参数类型尤其重要。最初的开发人员可能不明白这一点,如从 windll 转换为 cdll 接口所示。 windll 使用 __stdcall 호출 규칙과 매개변수 크기를 알아야 합니다.

예를 들어 hpdf_doc 被定义为 hpdf_handle,它被定义为 ctypes.c_void_p。这是 64 位操作系统上的 64 位指针。 hpdf_newhpdf_addpage는 다음과 같이 정의됩니다.

으아악

ctypes 假设传递给 hpdf_addpage 的参数是 c_int 因为 to 没有 argtypes。句柄值是 >32 位,因此出现错误。理想情况下,所有函数都应显式声明其参数类型,以便 ctypes 유형 검사를 수행하고 Python 객체의 매개변수를 C 유형으로 올바르게 마샬링(변환)할 수 있습니다. 예:

으아악

매개변수 유형은 ctypes 类型。您必须仔细跟踪参数并为每个函数声明 .argtypes를 기반으로 해야 합니다.

위 내용은 LibHaru의 Python 바인딩을 Python 3.9(64비트)로 업데이트해 본 사람이 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

2018-2024 USD의 Bitcoin의 최신 가격 2018-2024 USD의 Bitcoin의 최신 가격 Feb 15, 2025 pm 07:12 PM

실시간 비트 코인 USD 가격 비트 코인 가격에 영향을 미치는 요인 향후 비트 코인 가격을 예측하기위한 지표 다음은 2018-2024 년 비트 코인 가격에 대한 몇 가지 주요 정보입니다.

H5 페이지 제작은 프론트 엔드 개발입니까? H5 페이지 제작은 프론트 엔드 개발입니까? Apr 05, 2025 pm 11:42 PM

예, H5 페이지 제작은 HTML, CSS 및 JavaScript와 같은 핵심 기술을 포함하는 프론트 엔드 개발을위한 중요한 구현 방법입니다. 개발자는 & lt; canvas & gt; 그래픽을 그리거나 상호 작용 동작을 제어하기 위해 JavaScript를 사용하는 태그.

CSS를 통해 크기 조정 기호를 사용자 정의하고 배경색으로 균일하게 만드는 방법은 무엇입니까? CSS를 통해 크기 조정 기호를 사용자 정의하고 배경색으로 균일하게 만드는 방법은 무엇입니까? Apr 05, 2025 pm 02:30 PM

CSS에서 크기 조정 기호를 사용자 정의하는 방법은 배경색으로 통합됩니다. 매일 개발에서, 우리는 종종 조정과 같은 사용자 인터페이스 세부 정보를 사용자 정의 해야하는 상황을 발생시킵니다.

인라인 블록 요소가 왜 잘못 정렬됩니까? 이 문제를 해결하는 방법? 인라인 블록 요소가 왜 잘못 정렬됩니까? 이 문제를 해결하는 방법? Apr 04, 2025 pm 10:39 PM

인라인 블록 요소의 잘못 정렬 된 디스플레이에 대한 이유와 솔루션과 관련하여. 웹 페이지 레이아웃을 작성할 때, 우리는 종종 이상하게 겉보기에 이상한 디스플레이 문제가 발생합니다. 비교하다...

JavaScript 또는 CSS를 통해 브라우저 인쇄 설정에서 페이지 상단 및 끝을 제어하는 ​​방법은 무엇입니까? JavaScript 또는 CSS를 통해 브라우저 인쇄 설정에서 페이지 상단 및 끝을 제어하는 ​​방법은 무엇입니까? Apr 05, 2025 pm 10:39 PM

브라우저의 인쇄 설정에서 페이지의 상단과 끝을 제어하기 위해 JavaScript 또는 CSS를 사용하는 방법. 브라우저의 인쇄 설정에는 디스플레이가 ...인지 제어 할 수있는 옵션이 있습니다.

CSS의 클립 경로 속성을 사용하여 세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? CSS의 클립 경로 속성을 사용하여 세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? Apr 04, 2025 pm 11:45 PM

세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? 세분화 장치를 구현하는 과정에서 왼쪽 버튼을 클릭 할 때 오른쪽 테두리를 45도 곡선으로 바꾸는 방법과 포인트 ...

플렉스 레이아웃 아래의 텍스트는 생략되지만 컨테이너가 열려 있습니까? 그것을 해결하는 방법? 플렉스 레이아웃 아래의 텍스트는 생략되지만 컨테이너가 열려 있습니까? 그것을 해결하는 방법? Apr 05, 2025 pm 11:00 PM

Flex 레이아웃 및 솔루션에서 텍스트를 과도하게 누락하여 컨테이너 개구부 문제가 사용됩니다 ...

45도 곡선 테두리로 분할 효과를 달성하는 방법? 45도 곡선 테두리로 분할 효과를 달성하는 방법? Apr 04, 2025 pm 11:48 PM

사용자 인터페이스 디자인에서 세그먼트 효과를 구현하기위한 팁, 세그먼터는 특히 모바일 애플리케이션 및 반응 형 웹 페이지에서 일반적인 탐색 요소입니다. ...

See all articles