Provided by: libchardet-dev_1.0.4-1_amd64
이름
detect_handledata - 문자셋과 정확도를 측정
사용법
#include <chardet.h> short chardet_handledata (Detect ** handle, const char * inbuf, DetectObj ** outbuf);
설명
inbuf 의 문자셋과 정확도를 outbuf에 저장한다. handle detect_init api에 의하여 할당된 detect handle resource. inbuf 문자셋과 정확도를 측정할 입력 문자열 outbuf inbuf 의 문자셋과 정확도를 구하여 저장을 한다. outbuf 의 구조는 다음과 같다. typedef struct DetectObject { char * encoding; float confidence; } DetectObj; outbuf는 detect_obj_init api를 이용하여 초기화를 한 후에 detect api로 넘겨줘야 한다.
반환값
경우에 따라 아래의 상태를 반환한다. CHARDET_SUCCESS 성공 CHARDET_NO_RESULT 탐지하지 못했을 경우 CHARDET_NULL_OBJECT outbuf 을 chardet_obj_init api를 이용하여 메모리 할당을 하지 않았을 경우. CHARDET_OUT_OF_MEMORY 내부 API에서 out of memory 가 발생했을 경우
예제
#include <chardet.h> int main (void) { Detect * d; DetectObj * obj; int i, arrayNum; char *str[] = { "this is ascii", "이건 euc-kr 입니다." }; arrayNum = sizeof (str) / sizeof (str[0]); if ( (d = detect_init ()) == NULL ) { fprintf (stderr, "chardet handle initialize failed\n"); return CHARDET_MEM_ALLOCATED_FAIL; } for ( i=0; i<arrayNum; i++ ) { detect_reset (&d); if ( (obj = detect_obj_init ()) == NULL ) { fprintf (stderr, "Memory Allocation failed\n"); return CHARDET_MEM_ALLOCATED_FAIL; } switch (detect_handledata (&d, "안녕하세요", &obj)) { case CHARDET_OUT_OF_MEMORY : fprintf (stderr, "On handle processing, occured out of memory\n"); detect_obj_free (&obj); return CHARDET_OUT_OF_MEMORY; case CHARDET_NULL_OBJECT : fprintf (stderr, "2st argument of chardet() is must memory allocation " "with detect_obj_init API\n"); return CHARDET_NULL_OBJECT; } printf ("encoding: %s, confidence: %f\n", obj->encoding, obj->confidence); detect_obj_free (&obj); } detect_destroy (&d); return 0; }
저자
김정균
버그 리포트
<http://oops.org> 의 QnA 게시판을 이용한다.
참고
detect_obj_init(3), detect_obj_free(3), detect_init(3), detect_reset(3), detect_destroy(3)