유니코드 객체와 코덱¶
유니코드 객체¶
파이썬 3.3에서 PEP 393을 구현한 이후, 유니코드 객체는 내부적으로 다양한 표현을 사용하여 전체 유니코드 문자 범위를 처리하면서 메모리 효율성을 유지합니다. 모든 코드 포인트가 128, 256 또는 65536 미만인 문자열에 대한 특별한 경우가 있습니다; 그렇지 않으면, 코드 포인트는 1114112 (전체 유니코드 범위) 미만이어야 합니다.
UTF-8 표현은 필요에 따라 생성되며 Unicode 객체에 캐시됩니다.
참고
Py_UNICODE 표현은 폐지된 API와 함께 파이썬 3.12에서 제거되었습니다. 자세한 정보는 PEP 623을 참조하십시오.
유니코드 형¶
다음은 파이썬에서 유니코드 구현에 사용되는 기본 유니코드 객체 형입니다:
-
PyTypeObject PyUnicode_Type¶
- …의 일부 안정 ABI.
이
PyTypeObject인스턴스는 파이썬 Unicode 형을 나타냅니다. 이는 파이썬 코드에서str로 노출됩니다.
-
PyTypeObject PyUnicodeIter_Type¶
- …의 일부 안정 ABI.
이
PyTypeObject인스턴스는 파이썬 Unicode 반복자 형을 나타냅니다. 이는 Unicode 문자열 객체를 반복하는 데 사용됩니다.
-
type Py_UCS4¶
-
type Py_UCS2¶
-
type Py_UCS1¶
- …의 일부 안정 ABI.
이 형들은 각각 32비트, 16비트 및 8비트의 문자를 포함하기에 충분한 부호 없는 정수 형을 위한 typedef 입니다. 단일 유니코드 문자를 처리할 때는,
Py_UCS4를 사용하십시오.Added in version 3.3.
-
type PyASCIIObject¶
-
type PyCompactUnicodeObject¶
-
type PyUnicodeObject¶
이
PyObject서브 형들은 파이썬 유니코드 객체를 나타냅니다. 거의 모든 경우에, 유니코드 객체를 처리하는 모든 API 함수가PyObject포인터를 취하고 반환하므로 직접 사용해서는 안 됩니다.Added in version 3.3.
특정 객체의 구조는 다음 매크로를 사용하여 확인할 수 있습니다. 이 매크로는 실패하지 않으며, 인자가 파이썬 Unicode 객체가 아닐 경우 동작이 정의되지 않습니다.
-
PyUnicode_IS_COMPACT(o)¶
o 가
PyCompactUnicodeObject구조를 사용하는 경우 True를 반환합니다.Added in version 3.3.
-
PyUnicode_IS_COMPACT_ASCII(o)¶
o 가
PyASCIIObject구조를 사용하는 경우 True를 반환합니다.Added in version 3.3.
-
PyUnicode_IS_COMPACT(o)¶
다음 API는 빠른 검사를 수행하고 유니코드 객체의 내부 읽기 전용 데이터에 액세스하는 데 사용할 수 있는 C 매크로와 정적 인라인 함수입니다:
-
int PyUnicode_CheckExact(PyObject *obj)¶
객체 obj가 유니코드 객체이지만, 서브 형의 인스턴스가 아니면 참을 반환합니다. 이 함수는 항상 성공합니다.
-
Py_ssize_t PyUnicode_GET_LENGTH(PyObject *unicode)¶
유니코드 문자열의 길이를 코드 포인트로 반환합니다. unicode는 “규범적(canonical)” 표현의 유니코드 객체여야 합니다 (검사하지 않습니다).
Added in version 3.3.
-
Py_UCS1 *PyUnicode_1BYTE_DATA(PyObject *unicode)¶
-
Py_UCS2 *PyUnicode_2BYTE_DATA(PyObject *unicode)¶
-
Py_UCS4 *PyUnicode_4BYTE_DATA(PyObject *unicode)¶
직접 문자 액세스를 위해 UCS1, UCS2 또는 UCS4 정수 형으로 캐스트 된 규범적(canonical) 표현에 대한 포인터를 반환합니다. 규범적(canonical) 표현이 올바른 문자 크기인지 검사하지 않습니다;
PyUnicode_KIND()를 사용하여 올바른 함수를 선택하십시오.Added in version 3.3.
-
PyUnicode_1BYTE_KIND¶
-
PyUnicode_2BYTE_KIND¶
-
PyUnicode_4BYTE_KIND¶
PyUnicode_KIND()매크로의 값을 반환합니다.Added in version 3.3.
버전 3.12에서 변경:
PyUnicode_WCHAR_KIND는 제거되었습니다.
-
int PyUnicode_KIND(PyObject *unicode)¶
이 유니코드 객체가 데이터를 저장하는 데 사용하는 문자 당 바이트 수를 나타내는 PyUnicode 종류 상수 (위를 참조하십시오) 중 하나를 반환합니다. unicode는 “규범적(canonical)” 표현의 유니코드 객체여야 합니다 (검사하지 않습니다).
Added in version 3.3.
-
void *PyUnicode_DATA(PyObject *unicode)¶
원시 유니코드 버퍼에 대한 void 포인터를 반환합니다. unicode는 “규범적(canonical)” 표현의 유니코드 객체여야 합니다 (검사하지 않습니다).
Added in version 3.3.
-
void PyUnicode_WRITE(int kind, void *data, Py_ssize_t index, Py_UCS4 value)¶
문자열의 지정된 0부터 시작하는 인덱스에 코드 포인트 value 를 기록합니다.
kind 값과 data 포인터는 각각
PyUnicode_KIND()및PyUnicode_DATA()를 사용하여 문자열로부터 얻은 것이어야 합니다.PyUnicode_WRITE()를 호출하는 동안 해당 문자열에 대한 참조를 유지해야 합니다. 또한PyUnicode_WriteChar()의 모든 요구 사항도 적용됩니다.이 함수는 요구 사항에 대한 어떠한 확인도 수행하지 않으며, 반복문 내에서 사용하도록 설계되었습니다.
Added in version 3.3.
-
Py_UCS4 PyUnicode_READ(int kind, void *data, Py_ssize_t index)¶
규범적(canonical) 표현 data(
PyUnicode_DATA()로 얻은 대로)에서 코드 포인트를 읽습니다. 검사나 준비(ready) 호출이 수행되지 않습니다.Added in version 3.3.
-
Py_UCS4 PyUnicode_READ_CHAR(PyObject *unicode, Py_ssize_t index)¶
“규범적(canonical)” 표현이어야 하는, 유니코드 객체 unicode에서 문자를 읽습니다. 여러 연속 읽기를 수행한다면
PyUnicode_READ()보다 효율성이 떨어집니다.Added in version 3.3.
-
Py_UCS4 PyUnicode_MAX_CHAR_VALUE(PyObject *unicode)¶
“규범적(canonical)” 표현이어야 하는, unicode를 기반으로 다른 문자열을 만드는 데 적합한 최대 코드 포인트를 반환합니다. 이것은 항상 근사치이지만 문자열을 이터레이트 하는 것보다 효율적입니다.
Added in version 3.3.
-
int PyUnicode_IsIdentifier(PyObject *unicode)¶
- …의 일부 안정 ABI.
언어 정의에 따라 문자열이 유효한 식별자이면
1을 반환합니다, 섹션 이름(식별자 및 키워드). 그렇지 않으면0을 반환합니다.버전 3.9에서 변경: 문자열이 준비(ready)되지 않았을 때, 이 함수는 더는
Py_FatalError()를 호출하지 않습니다.
-
unsigned int PyUnicode_IS_ASCII(PyObject *unicode)¶
문자열이 오직 ASCII 문자만 포함하는 경우 true를 반환합니다.
str.isascii()와 동일합니다.Added in version 3.2.
-
Py_hash_t PyUnstable_Unicode_GET_CACHED_HASH(PyObject *str)¶
- 이것은 불안정 API. 마이너 릴리스에서 예고 없이 변경될 수 있습니다.
PyObject_Hash()에 의해 반환되는 str 의 해시가 캐싱되어 즉시 사용 가능한 경우 해당 값을 반환합니다. 그렇지 않은 경우 예외를 설정하지 않고-1을 반환합니다.str 이 문자열이 아닌 경우(즉,
PyUnicode_Check(obj)가 false인 경우), 동작은 정의되지 않습니다.이 함수는 절대로 예외를 발생시키지 않습니다.
객체의 해시가 언제 캐싱되는지 보장할 수 없으며, 캐시된 해시의 존재 여부가 문자열이 다른 속성을 가지고 있음을 의미하지는 않는다는 점에 유의하십시오.
유니코드 문자 속성¶
유니코드는 다양한 문자 속성을 제공합니다. 가장 자주 필요한 것은 파이썬 구성에 따라 C 함수에 매핑되는 이러한 매크로를 통해 사용할 수 있습니다.
-
int Py_UNICODE_ISPRINTABLE(Py_UCS4 ch)¶
ch가
str.isprintable()의 의미에서 인쇄 가능한 문자인지에 따라1이나0을 반환합니다.
다음 API는 빠른 직접 문자 변환에 사용할 수 있습니다:
-
int Py_UNICODE_TODECIMAL(Py_UCS4 ch)¶
10진 양의 정수로 변환된 문자 ch를 반환합니다. 이것이 불가능하면
-1을 반환합니다. 이 함수는 예외를 발생시키지 않습니다.
-
int Py_UNICODE_TODIGIT(Py_UCS4 ch)¶
한 자리 정수로 변환된 문자 ch를 반환합니다. 이것이 불가능하면
-1을 반환합니다. 이 함수는 예외를 발생시키지 않습니다.
-
double Py_UNICODE_TONUMERIC(Py_UCS4 ch)¶
double로 변환된 문자 ch를 반환합니다. 이것이 불가능하면
-1.0을 반환합니다. 이 함수는 예외를 발생시키지 않습니다.
다음 API를 사용하여 서로게이트를 다룰 수 있습니다:
-
Py_UCS4 Py_UNICODE_HIGH_SURROGATE(Py_UCS4 ch)¶
범위가
[0x10000; 0x10FFFF]``인 유니코드 코드 포인트에 대해 높은 UTF-16 대리자(``0xD800``~``0xDBFF)를 반환합니다.
유니코드 문자열 생성과 액세스¶
유니코드 객체를 만들고 기본 시퀀스 속성에 액세스하려면 다음 API를 사용하십시오:
-
PyObject *PyUnicode_New(Py_ssize_t size, Py_UCS4 maxchar)¶
- 반환값: 새 참조.
새 유니코드 객체를 만듭니다. maxchar은 문자열에 배치할 실제 최대 코드 포인트여야 합니다. 근삿값으로, 127, 255, 65535, 1114111 시퀀스에서 가장 가까운 값으로 올림 할 수 있습니다.
오류 시 예외를 설정하고
NULL을 반환합니다.생성 후 이 문자열은
PyUnicode_WriteChar(),PyUnicode_CopyCharacters(),PyUnicode_Fill(),PyUnicode_WRITE()또는 유사한 함수에 의해 채워질 수 있습니다. 문자열은 불변이어야 하므로, 수정 중인 상태에서 결과를 “사용”하지 않도록 주의하십시오. 특히, 최종 내용으로 채워지기 전의 문자열은:해싱되어서는 안 되며,
converted to UTF-8또는 다른 비 “규범적(canonical)” 표현으로 변환되어서는 안 되며,참조 횟수가 변경되어서는 안 되며,
위의 작업 중 하나를 수행할 수 있는 코드와 공유되어서는 안 됩니다.
이 목록은 전부가 아닙니다. 이러한 사용 사례를 피하는 것은 사용자 책임이며, 파이썬이 항상 이 요구 사항들을 확인하지는 않습니다.
부분적으로 작성된 문자열 객체가 실수로 노출되는 것을 방지하려면
PyUnicodeWriterAPI 또는 아래의PyUnicode_From*함수 중 하나를 사용하는 것이 좋습니다.Added in version 3.3.
-
PyObject *PyUnicode_FromKindAndData(int kind, const void *buffer, Py_ssize_t size)¶
- 반환값: 새 참조.
주어진 kind(가능한 값은
PyUnicode_KIND()에 의해 반환된PyUnicode_1BYTE_KIND등입니다)로 새로운 유니코드 객체를 만듭니다. buffer는 kind에 따라 문자 당 1, 2 또는 4바이트의 size 단위의 배열을 가리켜야 합니다.필요한 경우 입력 buffer 는 복사되어 규범적(canonical) 표현으로 변환됩니다. 예를 들어, buffer 가 UCS4 문자열(
PyUnicode_4BYTE_KIND)이지만 모든 코드 포인트가 UCS1 범위에 속한다면, 이는 UCS1(PyUnicode_1BYTE_KIND)로 변환됩니다.Added in version 3.3.
-
PyObject *PyUnicode_FromStringAndSize(const char *str, Py_ssize_t size)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
char 버퍼 str에서 유니코드 객체를 만듭니다. 바이트는 UTF-8로 인코딩된 것으로 해석됩니다. 버퍼는 새 객체에 복사됩니다. 반환 값은 공유 객체일 수 있습니다, 즉, 데이터 수정이 허용되지 않습니다.
이 함수는 다음과 같은 경우에
SystemError를 발생시킵니다:size < 0,
str 이
NULL이고 size 가 0보다 큰 경우
버전 3.12에서 변경: size 가 0보다 클 때 str 이
NULL인 경우는 더 이상 허용되지 않습니다.
-
PyObject *PyUnicode_FromString(const char *str)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
UTF-8로 인코딩된 널-종료 char 버퍼 str에서 유니코드 객체를 만듭니다.
-
PyObject *PyUnicode_FromFormat(const char *format, ...)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
C
printf()-스타일 format 문자열과 가변 개수의 인자를 취해서, 결과 파이썬 유니코드 문자열의 크기를 계산하고 포맷된 값이 들어간 문자열을 반환합니다. 변수 인자는 C형이어야 하며 format ASCII 인코딩된 문자열의 포맷 문자와 정확히 일치해야 합니다.변환 지정자는 두 개 이상의 문자로 구성되며, 다음 구성 요소들을 아래 순서대로 포함해야 합니다:
지정자의 시작을 나타내는
'%'문자.일부 변환 유형의 결과에 영향을 미치는 변환 플래그(선택 사항).
최소 필드 폭(선택 사항).
'*'(애스터리스크)로 지정된 경우 실제 너비는 다음 인자에서 제공되며, 해당 인자는 반드시 int 타입이어야 하며, 변환할 객체는 최소 필드 폭과 선택적 정밀도 뒤에 위치합니다.정밀도(선택 사항).
'.'(점) 뒤에 정밀도가 오며,'*'(애스터리스크)로 지정된 경우 실제 정밀도는 다음 인자에서 제공됩니다. 해당 인자는 반드시 int 타입이어야 하며, 변환할 값은 정밀도 뒤에 위치합니다.길이 수정자(선택 사항).
변환 유형.
변환 플래그 문자는 다음과 같습니다:
플래그
의미
0숫자 값의 경우 변환 시 0으로 채웁니다.
-변환된 값은 왼쪽 정렬됩니다(둘 다 제공된 경우
0플래그보다 우선합니다).다음 정수 변환(
d,i,o,u,x또는X)에 대한 길이 수정자는 인자의 타입을 지정합니다(기본값은 int):수정자
형
llong 또는 unsigned long
lllong long 또는 unsigned long long
jintmax_t또는uintmax_tzsize_t또는ssize_ttptrdiff_t다음 변환
s또는V에 대한 길이 수정자l은 인자의 타입이 const wchar_t* 임을 의미합니다.변환 지정자는 다음과 같습니다:
변환 지정자
형
주석
%n/a
리터럴
%문자.d,i길이 수정자에 의해 지정됨
부호 있는 C 정수의 10진수 표현.
u길이 수정자에 의해 지정됨
부호 없는 C 정수의 10진수 표현.
o길이 수정자에 의해 지정됨
부호 없는 C 정수의 8진수 표현.
x길이 수정자에 의해 지정됨
부호 없는 C 정수의 16진수 표현(소문자).
X길이 수정자에 의해 지정됨
부호 없는 C 정수의 16진수 표현(대문자).
cint
단일 문자.
sconst char* 또는 const wchar_t*
널-종료 C 문자 배열.
pconst void*
C 포인터의 16진수 표현. 플랫폼의
printf가 산출하는 내용과 관계없이 리터럴0x로 시작하는 것이 보장된다는 점을 제외하면 거의printf("%p")와 동등합니다.Aascii()를 호출한 결과.U유니코드 객체.
VPyObject*, const char* 또는 const wchar_t*
유니코드 객체(
NULL일 수 있습니다)와 두 번째 매개 변수로서 널-종료 C 문자 배열 (첫 번째 매개 변수가NULL이면 사용됩니다).SPyObject_Str()을 호출한 결과.RPyObject_Repr()을 호출한 결과.T객체 유형의 전체 이름을 가져옵니다.
PyType_GetFullyQualifiedName()을 호출하십시오.#TT형식과 유사하지만 모듈 이름과 전체 이름 사이에 콜론(:)을 구분자로 사용합니다.N타입의 전체 이름을 가져옵니다.
PyType_GetFullyQualifiedName()을 호출하십시오.#NN형식과 유사하지만 모듈 이름과 전체 이름 사이에 콜론(:)을 구분자로 사용합니다.참고
너비 포매터 단위는 바이트가 아닌 문자 수입니다. 정밀도 포매터 단위는
"%s"와"%V"의 경우는 바이트 수나 (길이 수정자l이 사용되면)wchar_t항목이고 (PyObject*인자가NULL이면),"%A","%U","%S","%R"및"%V"의 경우 문자 수입니다 (PyObject*인자가NULL이 아니면).참고
C 언어의
printf()와 달리 정수 변환(d,i,u,o,x또는X) 시 정밀도가 지정된 경우에도0플래그가 효과를 발휘합니다.버전 3.2에서 변경:
"%lld"와"%llu"에 대한 지원이 추가되었습니다.버전 3.3에서 변경:
"%li","%lli"및"%zi"에 대한 지원이 추가되었습니다.버전 3.4에서 변경:
"%s","%A","%U","%V","%S","%R"에 대한 너비와 정밀도 포매터 지원이 추가되었습니다.버전 3.12에서 변경: 변환 지정자
o및X지원. 길이 수정자j및t지원. 이제 길이 수정자가 모든 정수 변환에 적용됩니다. 길이 수정자l``이 변환 지정자 ``s및V``에 적용됩니다. 가변 너비 및 정밀도 ``*지원. 플래그-지원.인식할 수 없는 포맷 문자는 이제
SystemError를 설정합니다. 이전 버전에서는 나머지 포맷 문자열이 모두 결과 문자열에 그대로 복사되고, 추가 인자는 버려지도록 했습니다.버전 3.13에서 변경:
%T,%#T,%N및%#N에 대한 지원이 추가되었습니다.
-
PyObject *PyUnicode_FromFormatV(const char *format, va_list vargs)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
정확히 두 개의 인자를 취한다는 점을 제외하면
PyUnicode_FromFormat()과 동일합니다.
-
PyObject *PyUnicode_FromObject(PyObject *obj)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
필요하면 유니코드 서브 형의 인스턴스를 새로운 진짜 유니코드 객체에 복사합니다. obj가 이미 (서브 형이 아닌) 진짜 유니코드 객체이면, 객체에 대한 새로운 강한 참조를 반환합니다.
유니코드나 이의 서브 형 이외의 객체는
TypeError를 발생시킵니다.
-
PyObject *PyUnicode_FromOrdinal(int ordinal)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
주어진 유니코드 코드 포인트 ordinal로 유니코드 객체를 만듭니다.
서수는
range(0x110000)내에 있어야 합니다. 그렇지 않을 경우ValueError가 발생합니다.
-
PyObject *PyUnicode_FromEncodedObject(PyObject *obj, const char *encoding, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
인코딩된 객체 obj를 유니코드 객체로 디코딩합니다.
bytes,bytearray및 기타 바이트열류 객체는 주어진 encoding에 따라 errors로 정의한 에러 처리를 사용하여 디코딩됩니다. 둘 다NULL이 될 수 있고, 이 경우 인터페이스는 기본값을 사용합니다 (자세한 내용은 내장 코덱를 참조하십시오).유니코드 객체를 포함한 다른 모든 객체는
TypeError가 설정되도록 합니다.API는 에러가 있으면
NULL을 반환합니다. 호출자는 반환된 객체의 참조 횟수를 감소시킬 책임이 있습니다.
-
void PyUnicode_Append(PyObject **p_left, PyObject *right)¶
- …의 일부 안정 ABI.
right 문자열을 p_left 끝에 추가합니다. p_left 는 유니코드 객체에 대한 strong reference 를 가리켜야 하며,
PyUnicode_Append()은 이 참조를 해제(steal)합니다.오류 발생 시 *p_left 을
NULL로 설정하고 예외를 생성합니다.성공 시 *p_left 을 결과에 대한 새로운 strong reference로 설정합니다.
-
void PyUnicode_AppendAndDel(PyObject **p_left, PyObject *right)¶
- …의 일부 안정 ABI.
이 함수는
PyUnicode_Append()와 유사하며, 유일한 차이점은 right 의 참조 횟수를 1만큼 감소시킨다는 것입니다.
-
PyObject *PyUnicode_BuildEncodingMap(PyObject *string)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
커스텀 단일 바이트 인코딩을 디코딩하는 데 적합한 매핑을 반환합니다. 인코딩 테이블을 나타내는 최대 256자의 유니코드 문자열 string 이 주어지면, 압축된 내부 매핑 객체 또는 문자의 오디널을 바이트 값으로 매핑하는 딕셔너리 중 하나를 반환합니다. 잘못된 입력의 경우
TypeError를 발생시키고NULL을 반환합니다.Added in version 3.2.
-
const char *PyUnicode_GetDefaultEncoding(void)¶
- …의 일부 안정 ABI.
기본 문자열 인코딩인
"utf-8"을 반환합니다. 자세한 내용은sys.getdefaultencoding()을 참조하십시오.반환된 문자열은 해제할 필요가 없으며, 인터프리터 종료 시까지 유효합니다.
-
Py_ssize_t PyUnicode_GetLength(PyObject *unicode)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
유니코드 객체의 길이를 코드 포인트로 반환합니다.
에러 발생 시 예외를 설정하고
-1을 반환합니다.Added in version 3.3.
-
Py_ssize_t PyUnicode_CopyCharacters(PyObject *to, Py_ssize_t to_start, PyObject *from, Py_ssize_t from_start, Py_ssize_t how_many)¶
한 유니코드 객체에서 다른 객체로 문자를 복사합니다. 이 함수는 필요하면 문자 변환을 수행하고 가능하면
memcpy()로 폴백합니다. 에러 시-1을 반환하고 예외를 설정합니다, 그렇지 않으면 복사된 문자 수를 반환합니다.문자열이 아직 “사용”된 상태가 아니어야 합니다. 자세한 내용은
PyUnicode_New()을 참조하십시오.Added in version 3.3.
-
int PyUnicode_Resize(PyObject **unicode, Py_ssize_t length);¶
- …의 일부 안정 ABI.
유니코드 객체 *unicode 의 크기를 새로운 코드 포인트 수인 length 로 조정합니다.
문자열을 제자리에서 크기 조정(새 문자열을 할당하고 문자를 복사하는 것보다 일반적으로 빠름)하거나, 새 문자열을 생성합니다.
*unicode 이 새(크기 조정된) 객체를 가리키도록 수정되며 성공 시
0이 반환됩니다. 그렇지 않으면-1이 반환되고 예외가 설정되며, *unicode 는 변경되지 않은 채로 유지됩니다.이 함수는 문자열 내용을 확인하지 않으므로 결과가 규범적(canonical) 표현의 문자열이 아닐 수 있습니다.
-
Py_ssize_t PyUnicode_Fill(PyObject *unicode, Py_ssize_t start, Py_ssize_t length, Py_UCS4 fill_char)¶
문자로 문자열을 채웁니다: fill_char을
unicode[start:start+length]에 씁니다.fill_char이 문자열 최대 문자보다 크거나, 문자열에 둘 이상의 참조가 있으면 실패합니다.
문자열이 아직 “사용”된 상태가 아니어야 합니다. 자세한 내용은
PyUnicode_New()을 참조하십시오.기록된 문자의 수를 반환하거나, 에러 시
-1을 반환하고 예외를 발생시킵니다.Added in version 3.3.
-
int PyUnicode_WriteChar(PyObject *unicode, Py_ssize_t index, Py_UCS4 character)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
0부터 시작하는 인덱스인 index 에 있는 문자열 unicode 에 character 를 씁니다. 성공 시
0을 반환하며, 에러 시 예외를 설정하고-1을 반환합니다.이 함수는 unicode 가 유니코드 객체인지, 인덱스가 범위를 벗어나지 않았는지, 그리고 해당 객체의 참조 횟수가 하나인지 확인합니다. 이러한 검사를 생략하고 사용자 책임으로 돌리는 버전을 원하신다면
PyUnicode_WRITE()를 참조하십시오.문자열이 아직 “사용”된 상태가 아니어야 합니다. 자세한 내용은
PyUnicode_New()을 참조하십시오.Added in version 3.3.
-
Py_UCS4 PyUnicode_ReadChar(PyObject *unicode, Py_ssize_t index)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
문자열에서 문자를 읽습니다. 이 함수는 에러를 검사하지 않는
PyUnicode_READ_CHAR()와 달리 unicode가 유니코드 객체이고 인덱스가 범위를 벗어났는지 확인합니다.성공 시 문자를, 에러 시 예외를 설정하고
-1을 반환합니다.Added in version 3.3.
-
PyObject *PyUnicode_Substring(PyObject *unicode, Py_ssize_t start, Py_ssize_t end)¶
- 반환값: 새 참조. …의 일부 안정 ABI 버전 3.7 이후로.
문자 인덱스 start(포함합니다)에서 문자 인덱스 end(제외합니다)까지 unicode의 하위 문자열을 반환합니다. 음수 인덱스는 지원되지 않습니다. 에러 시, 예외를 설정하고
NULL을 반환합니다.Added in version 3.3.
-
Py_UCS4 *PyUnicode_AsUCS4(PyObject *unicode, Py_UCS4 *buffer, Py_ssize_t buflen, int copy_null)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
copy_null이 설정되면, 널 문자를 포함하여 문자열 unicode를 UCS4 버퍼에 복사합니다. 에러 시
NULL을 반환하고 예외를 설정합니다 (특히, buflen이 unicode의 길이보다 작으면SystemError). 성공하면 buffer가 반환됩니다.Added in version 3.3.
-
Py_UCS4 *PyUnicode_AsUCS4Copy(PyObject *unicode)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
문자열 unicode를
PyMem_Malloc()을 사용하여 할당된 새 UCS4 버퍼에 복사합니다. 이것이 실패하면,NULL이 반환되고MemoryError가 설정됩니다. 반환된 버퍼에는 항상 추가 널 코드 포인트가 있습니다.Added in version 3.3.
로케일 인코딩¶
현재 로케일 인코딩을 사용하여 운영 체제에서 온 텍스트를 디코딩 할 수 있습니다.
-
PyObject *PyUnicode_DecodeLocaleAndSize(const char *str, Py_ssize_t length, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI 버전 3.7 이후로.
안드로이드와 VxWorks의 UTF-8이나 다른 플랫폼의 현재 로케일 인코딩의 문자열을 디코딩합니다. 지원되는 에러 처리기는
"strict"와"surrogateescape"(PEP 383)입니다. 디코더는 errors가NULL이면"strict"에러 처리기를 사용합니다. str은 널 문자로 끝나야 하지만 널 문자를 포함할 수 없습니다.파일시스템 인코딩과 에러 처리기로 문자열을 디코딩하려면
PyUnicode_DecodeFSDefaultAndSize()를 사용하십시오.이 함수는 파이썬 UTF-8 모드를 무시합니다.
더 보기
Added in version 3.3.
버전 3.7에서 변경: 이 함수는 이제 안드로이드를 제외하고
surrogateescape에러 처리기에 현재 로케일 인코딩도 사용합니다. 이전에는,Py_DecodeLocale()이surrogateescape에 사용되었고, 현재 로케일 인코딩은strict에 사용되었습니다.
-
PyObject *PyUnicode_DecodeLocale(const char *str, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI 버전 3.7 이후로.
PyUnicode_DecodeLocaleAndSize()와 유사하지만,strlen()을 사용하여 문자열 길이를 계산합니다.Added in version 3.3.
-
PyObject *PyUnicode_EncodeLocale(PyObject *unicode, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI 버전 3.7 이후로.
유니코드 객체를 안드로이드와 VxWorks에서 UTF-8로 인코딩하거나, 다른 플랫폼에서 현재 로케일 인코딩으로 인코딩합니다. 지원되는 에러 처리기는
"strict"와"surrogateescape"(PEP 383)입니다. 인코더는 errors가NULL이면"strict"에러 처리기를 사용합니다.bytes객체를 반환합니다. unicode는 내장된 널 문자를 포함할 수 없습니다.파일시스템 인코딩과 에러 처리기로 문자열을 인코딩하려면
PyUnicode_EncodeFSDefault()를 사용하십시오.이 함수는 파이썬 UTF-8 모드를 무시합니다.
더 보기
Added in version 3.3.
버전 3.7에서 변경: 이 함수는 이제 안드로이드를 제외하고
surrogateescape에러 처리기에 현재 로케일 인코딩도 사용합니다. 이전에는Py_EncodeLocale()이surrogateescape에 사용되었고, 현재 로케일 인코딩은strict에 사용되었습니다.
파일 시스템 인코딩¶
Functions encoding to and decoding from the filesystem encoding and error handler (PEP 383 and PEP 529).
인자 구문 분석 중에 파일 이름을 bytes로 인코딩하려면, "O&" 변환기를 사용하고 PyUnicode_FSConverter()를 변환 함수로 전달해야 합니다:
-
int PyUnicode_FSConverter(PyObject *obj, void *result)¶
- …의 일부 안정 ABI.
PyArg_Parse* 변환기: (직접 또는
os.PathLike인터페이스를 통해 얻은)str객체를PyUnicode_EncodeFSDefault()를 사용하여bytes로 인코딩합니다;bytes객체는 있는 그대로의 출력입니다. result는 형이 PyObject* (또는 PyBytesObject*) 인 C 변수의 주소여야 합니다. 성공 시, 더는 사용되지 않을 때 해제해야 하는 바이트열 객체에 대한 강한 참조로 변수를 설정하고 0이 아닌 값(Py_CLEANUP_SUPPORTED)을 반환합니다. 결과에 내장된 널 바이트는 허용되지 않습니다. 실패 시, 예외를 설정하고0을 반환합니다.obj 이
NULL이면, 이 함수는 result 가 가리키는 변수에 저장된 강력한 참조를 해제하고1을 반환합니다.Added in version 3.1.
버전 3.6에서 변경: 경로류 객체를 받아들입니다.
인자 구문 분석 중에 파일 이름을 str로 디코딩하려면, "O&" 변환기를 사용하고 PyUnicode_FSDecoder()를 변환 함수로 전달해야 합니다:
-
int PyUnicode_FSDecoder(PyObject *obj, void *result)¶
- …의 일부 안정 ABI.
PyArg_Parse* 변환기: (직접 또는
os.PathLike인터페이스를 통해 간접적으로 얻은)bytes객체를PyUnicode_DecodeFSDefaultAndSize()를 사용하여str로 디코딩합니다;str객체는 있는 그대로의 출력입니다. result는 형이 PyObject* (또는 PyUnicodeObject*) 인 C 변수의 주소여야 합니다. 성공 시, 더는 사용되지 않을 때 해제해야 하는 유니코드 객체에 대한 강한 참조로 변수를 설정하고 0이 아닌 값(Py_CLEANUP_SUPPORTED)을 반환합니다. 결과에 내장된 널 바이트는 허용되지 않습니다. 실패 시, 예외를 설정하고0을 반환합니다.obj 이
NULL이면, result 가 가리키는 객체에 대한 강력한 참조를 해제하고1을 반환합니다.Added in version 3.2.
버전 3.6에서 변경: 경로류 객체를 받아들입니다.
-
PyObject *PyUnicode_DecodeFSDefaultAndSize(const char *str, Py_ssize_t size)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
Decode a string from the filesystem encoding and error handler.
현재 로케일 인코딩에서 문자열을 디코딩해야 하면,
PyUnicode_DecodeLocaleAndSize()를 사용하십시오.더 보기
버전 3.6에서 변경: 이제 파일 시스템 에러 처리기 가 사용됩니다.
-
PyObject *PyUnicode_DecodeFSDefault(const char *str)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
파일시스템 인코딩과 에러 처리기로 널 종료 문자열을 디코딩합니다.
문자열 길이가 알려져 있으면,
PyUnicode_DecodeFSDefaultAndSize()를 사용하십시오.버전 3.6에서 변경: 이제 파일 시스템 에러 처리기 가 사용됩니다.
-
PyObject *PyUnicode_EncodeFSDefault(PyObject *unicode)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
유니코드 객체를 파일시스템 인코딩과 에러 처리기로 인코딩하고,
bytes를 반환합니다. 결과bytes객체에는 널 바이트가 포함될 수 있음에 유의하십시오.현재 로케일 인코딩으로 문자열을 인코딩해야 하면,
PyUnicode_EncodeLocale()을 사용하십시오.더 보기
Added in version 3.2.
버전 3.6에서 변경: 이제 파일 시스템 에러 처리기 가 사용됩니다.
wchar_t 지원¶
지원하는 플랫폼에 대한 wchar_t 지원:
-
PyObject *PyUnicode_FromWideChar(const wchar_t *wstr, Py_ssize_t size)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
주어진 size의
wchar_t버퍼 wstr에서 유니코드 객체를 만듭니다.-1을 size로 전달하면 함수가wcslen()을 사용하여 길이를 스스로 계산해야 함을 나타냅니다. 실패하면NULL을 반환합니다.
-
Py_ssize_t PyUnicode_AsWideChar(PyObject *unicode, wchar_t *wstr, Py_ssize_t size)¶
- …의 일부 안정 ABI.
유니코드 객체 내용을
wchar_t버퍼 wstr에 복사합니다. 최대 sizewchar_t문자가 복사됩니다 (후행 널 종료 문자가 제외될 수 있습니다). 복사된wchar_t문자 수나 에러가 발생하면-1을 반환합니다.wstr 이
NULL인 경우, 대신 종료용 널을 포함한 unicode 전체를 저장하는 데 필요한 size 를 반환합니다.결과 wchar_t* 문자열은 널로 종료될 수도 있고 아닐 수도 있음에 유의하십시오. 응용 프로그램에 필요하면 wchar_t* 문자열이 널로 끝나는지 확인하는 것은 호출자의 책임입니다. 또한, wchar_t* 문자열에는 널 문자가 포함될 수 있으며, 이로 인해 대부분의 C 함수와 함께 사용될 때 문자열이 잘리게 됨에 유의하십시오.
-
wchar_t *PyUnicode_AsWideCharString(PyObject *unicode, Py_ssize_t *size)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
유니코드 객체를 와이드 문자 문자열로 변환합니다. 출력 문자열은 항상 널 문자로 끝납니다. size가
NULL이 아니면, (후행 널 종료 문자를 제외한) 와이드 문자의 수를 *size에 씁니다. 결과wchar_t문자열이 널 문자를 포함할 수 있고, 이로 인해 대부분의 C 함수와 함께 사용될 때 문자열이 잘리게 됨에 유의하십시오. size가NULL이고 wchar_t* 문자열이 널 문자를 포함하면ValueError가 발생합니다.성공 시
PyMem_New에 의해 할당된 버퍼를 반환합니다 (PyMem_Free()를 사용하여 해제하십시오). 에러 시,NULL을 반환하고 *size는 정의되지 않습니다. 메모리 할당이 실패하면MemoryError를 발생시킵니다.Added in version 3.2.
버전 3.7에서 변경: size가
NULL이고 wchar_t* 문자열이 널 문자를 포함하면ValueError를 발생시킵니다.
내장 코덱¶
파이썬은 속도를 위해 C로 작성된 내장 코덱 집합을 제공합니다. 이러한 코덱들은 모두 다음 함수들을 통해 직접 사용할 수 있습니다.
다음 API의 대부분은 두 개의 인자 encoding과 errors를 취하며, 내장 str() 문자열 객체 생성자의 것들과 같은 의미입니다.
encoding을 NULL로 설정하면 기본 인코딩인 UTF-8이 사용됩니다. 파일 시스템 호출은 파일 이름 인코딩에 PyUnicode_FSConverter()를 사용해야 합니다. 이것은 내부적으로 파일시스템 인코딩과 에러 처리기를 사용합니다.
에러 처리는 errors로 설정되는데, 코덱에 대해 정의된 기본 처리를 사용함을 의미하는 NULL로 설정될 수도 있습니다. 모든 내장 코덱에 대한 기본 에러 처리는 “strict” 입니다 (ValueError가 발생합니다).
코덱은 모두 유사한 인터페이스를 사용합니다. 단순성을 위해 다음에 나오는 일반 코덱과의 차이만 설명합니다.
일반 코덱¶
다음 매크로가 제공됩니다:
-
Py_UNICODE_REPLACEMENT_CHARACTER¶
유니코드 코드 포인트
U+FFFD(대체 문자).errors 인수가 “replace”로 설정된 경우, 이 유니코드 문자가 디코딩 중 대체 문자로 사용됩니다.
다음은 일반 코덱 API입니다:
-
PyObject *PyUnicode_Decode(const char *str, Py_ssize_t size, const char *encoding, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. encoding과 errors는
str()내장 함수의 같은 이름의 매개 변수와 같은 의미입니다. 사용할 코덱은 파이썬 코덱 레지스트리를 사용하여 조회됩니다. 코덱에서 예외가 발생하면NULL을 반환합니다.
UTF-8 코덱¶
다음은 UTF-8 코덱 API입니다:
-
PyObject *PyUnicode_DecodeUTF8(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
UTF-8로 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
-
PyObject *PyUnicode_DecodeUTF8Stateful(const char *str, Py_ssize_t size, const char *errors, Py_ssize_t *consumed)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
consumed가
NULL이면,PyUnicode_DecodeUTF8()처럼 동작합니다. consumed가NULL이 아니면, 후행 불완전한 UTF-8 바이트 시퀀스는 에러로 처리되지 않습니다. 이러한 바이트는 디코딩되지 않으며 디코딩된 바이트 수는 consumed에 저장됩니다.
-
PyObject *PyUnicode_AsUTF8String(PyObject *unicode)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
UTF-8을 사용하여 유니코드 객체를 인코딩하고 결과를 파이썬 bytes 객체로 반환합니다. 에러 처리는 “strict” 입니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.문자열에 서로게이트 코드 포인트(
U+D800~U+DFFF)가 포함된 경우 이 함수는 실패합니다.
-
const char *PyUnicode_AsUTF8AndSize(PyObject *unicode, Py_ssize_t *size)¶
- …의 일부 안정 ABI 버전 3.10 이후로.
유니코드 객체의 UTF-8 인코딩에 대한 포인터를 반환하고, 인코딩된 표현의 크기를 (바이트 단위로) size에 저장합니다. size 인자는
NULL일 수 있습니다; 이 경우 크기가 저장되지 않습니다. 반환된 버퍼에는 다른 널 코드 포인트가 있는지에 관계없이, 항상 추가 널 바이트가 추가됩니다 (size에 포함되지 않습니다).에러 발생 시 예외를 설정하고, size 이 NULL이 아니면
-1로 설정하며NULL을 반환합니다.문자열에 서로게이트 코드 포인트(
U+D800~U+DFFF)가 포함된 경우 이 함수는 실패합니다.이것은 유니코드 객체에서 문자열의 UTF-8 표현을 캐시하고, 후속 호출은 같은 버퍼에 대한 포인터를 반환합니다. 호출자는 버퍼 할당 해제에 대한 책임이 없습니다. 유니코드 객체가 가비지 수거될 때 버퍼는 할당 해제되고 버퍼를 가리키는 포인터는 유효하지 않게 됩니다.
Added in version 3.3.
버전 3.7에서 변경: 반환 타입이 이제
char *대신const char *입니다.버전 3.10에서 변경: 이 함수는 제한된 API 의 일부입니다.
-
const char *PyUnicode_AsUTF8(PyObject *unicode)¶
PyUnicode_AsUTF8AndSize()와 같지만, 크기를 저장하지 않습니다.경고
이 함수는 unicode 내에 포함된 널 문자 <https://en.wikipedia.org/wiki/Null_character> 에 대해 특별한 동작을 수행하지 않습니다. 결과적으로 널 문자가 포함된 문자열은 반환되는 문자열에 그대로 남게 되며, 일부 C 함수에서는 이를 문자열의 끝으로 해석하여 잘림 현상이 발생할 수 있습니다. 잘림이 문제가 되는 경우
PyUnicode_AsUTF8AndSize()를 대신 사용하는 것을 권장합니다.Added in version 3.3.
버전 3.7에서 변경: 반환 타입이 이제
char *대신const char *입니다.
UTF-32 코덱¶
다음은 UTF-32 코덱 API입니다:
-
PyObject *PyUnicode_DecodeUTF32(const char *str, Py_ssize_t size, const char *errors, int *byteorder)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
UTF-32로 인코딩된 버퍼 문자열에서 size 바이트를 디코딩하고 해당 유니코드 객체를 반환합니다. errors(
NULL이 아니면)는 에러 처리를 정의합니다. 기본값은 “strict”입니다.byteorder가
NULL이 아니면, 디코더는 지정된 바이트 순서를 사용하여 디코딩을 시작합니다:*byteorder == -1: 리틀 엔디안 *byteorder == 0: 네이티브 엔디안 *byteorder == 1: 빅 엔디안
*byteorder가 0이고, 입력 데이터의 처음 4바이트가 바이트 순서 표시(BOM)이면, 디코더가 이 바이트 순서로 전환되고 BOM은 결과 유니코드 문자열에 복사되지 않습니다.*byteorder가-1이나1이면, 모든 바이트 순서 표시가 출력에 복사됩니다.완료 후, *byteorder는 입력 데이터의 끝에서 현재 바이트 순서로 설정됩니다.
byteorder가
NULL이면, 코덱은 네이티브 순서 모드로 시작합니다.코덱에서 예외가 발생하면
NULL을 반환합니다.
-
PyObject *PyUnicode_DecodeUTF32Stateful(const char *str, Py_ssize_t size, const char *errors, int *byteorder, Py_ssize_t *consumed)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
consumed가
NULL이면,PyUnicode_DecodeUTF32()처럼 동작합니다. consumed가NULL이 아니면,PyUnicode_DecodeUTF32Stateful()은 후행 불완전 UTF-32 바이트 시퀀스(가령 4로 나누어떨어지지 않는 바이트 수)를 에러로 처리하지 않습니다. 이러한 바이트는 디코딩되지 않으며 디코딩된 바이트 수는 consumed에 저장됩니다.
UTF-16 코덱¶
다음은 UTF-16 코덱 API입니다:
-
PyObject *PyUnicode_DecodeUTF16(const char *str, Py_ssize_t size, const char *errors, int *byteorder)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
UTF-16으로 인코딩된 버퍼 문자열에서 size 바이트를 디코딩하고 해당 유니코드 객체를 반환합니다. errors(
NULL이 아니면)는 에러 처리를 정의합니다. 기본값은 “strict”입니다.byteorder가
NULL이 아니면, 디코더는 지정된 바이트 순서를 사용하여 디코딩을 시작합니다:*byteorder == -1: 리틀 엔디안 *byteorder == 0: 네이티브 엔디안 *byteorder == 1: 빅 엔디안
*byteorder가 0이고, 입력 데이터의 처음 2바이트가 바이트 순서 표시(BOM)이면, 디코더는 이 바이트 순서로 전환되고 BOM은 결과 유니코드 문자열에 복사되지 않습니다.*byteorder가-1이나1이면 모든 바이트 순서 표시가 출력에 복사됩니다 (\ufeff나\ufffe문자가 됩니다).완료 후,
*byteorder는 입력 데이터의 끝에서 현재 바이트 순서로 설정됩니다.byteorder가
NULL이면, 코덱은 네이티브 순서 모드로 시작합니다.코덱에서 예외가 발생하면
NULL을 반환합니다.
-
PyObject *PyUnicode_DecodeUTF16Stateful(const char *str, Py_ssize_t size, const char *errors, int *byteorder, Py_ssize_t *consumed)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
consumed가
NULL이면,PyUnicode_DecodeUTF16()처럼 동작합니다. consumed가NULL이 아니면,PyUnicode_DecodeUTF16Stateful()은 후행 불완전 UTF-16 바이트 시퀀스(가령 홀수 바이트 수나 분할 서로게이트 쌍)를 에러로 처리하지 않습니다. 이러한 바이트는 디코딩되지 않으며 디코딩된 바이트 수는 consumed에 저장됩니다.
UTF-7 코덱¶
다음은 UTF-7 코덱 API입니다:
-
PyObject *PyUnicode_DecodeUTF7(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
UTF-7로 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
-
PyObject *PyUnicode_DecodeUTF7Stateful(const char *str, Py_ssize_t size, const char *errors, Py_ssize_t *consumed)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
consumed가
NULL이면,PyUnicode_DecodeUTF7()처럼 동작합니다. consumed가NULL이 아니면, 후행 불완전한 UTF-7 base-64 섹션은 에러로 처리되지 않습니다. 이러한 바이트는 디코딩되지 않으며 디코딩된 바이트 수는 consumed에 저장됩니다.
유니코드 이스케이프 코덱¶
다음은 “유니코드 이스케이프(Unicode Escape)” 코덱 API입니다:
-
PyObject *PyUnicode_DecodeUnicodeEscape(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
유니코드 이스케이프 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
원시 유니코드 이스케이프 코덱¶
다음은 “원시 유니코드 이스케이프(Raw Unicode Escape)” 코덱 API입니다:
-
PyObject *PyUnicode_DecodeRawUnicodeEscape(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
원시 유니코드 이스케이프 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
Latin-1 코덱¶
다음은 Latin-1 코덱 API입니다: Latin-1은 처음 256개의 유니코드 서수에 해당하며 인코딩 중에 코덱에서 이들만 허용됩니다.
-
PyObject *PyUnicode_DecodeLatin1(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
Latin-1 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
ASCII 코덱¶
다음은 ASCII 코덱 API입니다. 7비트 ASCII 데이터만 허용됩니다. 다른 모든 코드는 에러를 생성합니다.
-
PyObject *PyUnicode_DecodeASCII(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
ASCII 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
문자 맵 코덱¶
이 코덱은 다양한 코덱을 구현하는 데 사용할 수 있다는 점에서 특별합니다 (실제로 encodings 패키지에 포함된 대부분의 표준 코덱을 얻기 위해 수행되었습니다). 코덱은 매핑을 사용하여 문자를 인코딩하고 디코딩합니다. 제공된 매핑 객체는 __getitem__() 매핑 인터페이스를 지원해야 합니다; 딕셔너리와 시퀀스가 잘 작동합니다.
다음은 매핑 코덱 API입니다:
-
PyObject *PyUnicode_DecodeCharmap(const char *str, Py_ssize_t length, PyObject *mapping, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
주어진 mapping 객체를 사용하여 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.mapping이
NULL이면, Latin-1 디코딩이 적용됩니다. 그렇지 않으면 mapping은 바이트 서수(0에서 255 사이의 정수)를 유니코드 문자열, 정수(유니코드 서수로 해석됩니다) 또는None으로 매핑해야합니다. 매핑되지 않은 데이터 바이트(None,0xFFFE또는'\ufffe'로 매핑되는 것뿐만 아니라,LookupError를 유발하는 것)은 정의되지 않은 매핑으로 처리되어 에러를 발생시킵니다.
-
PyObject *PyUnicode_AsCharmapString(PyObject *unicode, PyObject *mapping)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
주어진 mapping 객체를 사용하여 유니코드 객체를 인코딩하고 결과를 bytes 객체로 반환합니다. 에러 처리는 “strict”입니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.mapping 객체는 유니코드 서수 정수를 bytes 객체, 0에서 255 사이의 정수 또는
None으로 매핑해야 합니다.None에 매핑되는 것뿐만 아니라 매핑되지 않은 문자 서수(LookupError를 유발하는 것)는 “정의되지 않은 매핑”으로 처리되어 에러가 발생합니다.
다음 코덱 API는 유니코드를 유니코드로 매핑한다는 점에서 특별합니다.
-
PyObject *PyUnicode_Translate(PyObject *unicode, PyObject *table, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
문자 매핑 테이블을 적용하여 문자열을 변환하고 결과 유니코드 객체를 반환합니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.매핑 테이블은 유니코드 서수 정수를 유니코드 서수 정수나
None(문자가 삭제되도록 합니다)에 매핑해야 합니다.매핑 테이블은
__getitem__()인터페이스 만 제공하면 됩니다; 딕셔너리와 시퀀스가 잘 작동합니다. 매핑되지 않은 문자 서수(LookupError를 유발하는 것)는 건드리지 않고 그대로 복사됩니다.errors는 코덱에서의 일반적인 의미입니다. 기본 에러 처리를 사용함을 나타내는
NULL일 수 있습니다.
윈도우 용 MBCS 코덱¶
다음은 MBCS 코덱 API입니다. 현재 윈도우에서만 사용할 수 있으며 Win32 MBCS 변환기를 사용하여 변환을 구현합니다. MBCS(또는 DBCS)는 단지 하나가 아니라 인코딩 클래스임에 유의하십시오. 대상 인코딩은 코덱을 실행하는 기계의 사용자 설정에 의해 정의됩니다.
-
PyObject *PyUnicode_DecodeMBCS(const char *str, Py_ssize_t size, const char *errors)¶
- 반환값: 새 참조. …의 일부 안정 ABI on Windows 버전 3.7 이후로.
MBCS 인코딩된 문자열 str의 size 바이트를 디코딩하여 유니코드 객체를 만듭니다. 코덱에서 예외가 발생하면
NULL을 반환합니다.
-
PyObject *PyUnicode_DecodeMBCSStateful(const char *str, Py_ssize_t size, const char *errors, Py_ssize_t *consumed)¶
- 반환값: 새 참조. …의 일부 안정 ABI on Windows 버전 3.7 이후로.
consumed가
NULL이면,PyUnicode_DecodeMBCS()처럼 동작합니다. consumed가NULL이 아니면,PyUnicode_DecodeMBCSStateful()은 후행 선행(lead) 바이트를 디코딩하지 않고 디코딩된 바이트 수가 consumed에 저장됩니다.
-
PyObject *PyUnicode_DecodeCodePageStateful(int code_page, const char *str, Py_ssize_t size, const char *errors, Py_ssize_t *consumed)¶
- 반환값: 새 참조. …의 일부 안정 ABI on Windows 버전 3.7 이후로.
PyUnicode_DecodeMBCSStateful()과 유사하지만, code_page 에 지정된 코드 페이지를 사용합니다.
메서드와 슬롯 함수¶
다음 API는 입력의 유니코드 객체와 문자열을 (설명에서 문자열이라고 하겠습니다) 처리할 수 있으며 적절하게 유니코드 객체나 정수를 반환합니다.
예외가 발생하면 모두 NULL이나 -1을 반환합니다.
-
PyObject *PyUnicode_Concat(PyObject *left, PyObject *right)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
두 문자열을 이어붙여 하나의 새로운 유니코드 문자열을 제공합니다.
-
PyObject *PyUnicode_Split(PyObject *unicode, PyObject *sep, Py_ssize_t maxsplit)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
문자열을 분할하여 유니코드 문자열 리스트를 제공합니다. sep이
NULL이면, 모든 공백 부분 문자열에서 분할이 수행됩니다. 그렇지 않으면, 주어진 구분자에서 분할이 일어납니다. 최대 maxsplit 분할이 수행됩니다. 음수이면, 제한이 설정되지 않습니다. 구분자는 결과 리스트에 포함되지 않습니다.에러 시, 예외를 설정하고
NULL을 반환합니다.str.split()와 동일합니다.
-
PyObject *PyUnicode_RSplit(PyObject *unicode, PyObject *sep, Py_ssize_t maxsplit)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
PyUnicode_Split()과 유사하지만, 문자열의 끝에서부터 분할을 수행합니다.에러 시, 예외를 설정하고
NULL을 반환합니다.str.rsplit()와 동일합니다.
-
PyObject *PyUnicode_Splitlines(PyObject *unicode, int keepends)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
줄 바꿈에서 유니코드 문자열을 분할하여, 유니코드 문자열 리스트를 반환합니다. CRLF는 하나의 줄 바꿈으로 간주합니다. keepends가
0이면, 결과 문자열에 줄 바꿈 문자가 포함되지 않습니다.
-
PyObject *PyUnicode_Partition(PyObject *unicode, PyObject *sep)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
sep 이 처음 나타나는 위치에서 유니코드 문자열을 분할하고, 구분자 이전 부분, 구분자 자체, 구분자 이후 부분으로 구성된 3-튜플을 반환합니다. 구분자를 찾지 못한 경우, 원본 문자열과 두 개의 빈 문자열로 구성된 3-튜플을 반환합니다.
sep 은 비어 있어서는 안 됩니다.
에러 시, 예외를 설정하고
NULL을 반환합니다.str.partition()과 동일합니다.
-
PyObject *PyUnicode_RPartition(PyObject *unicode, PyObject *sep)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
PyUnicode_Partition()과 유사하지만, 유니코드 문자열을 sep 이 마지막으로 나타나는 위치에서 분할합니다. 구분자를 찾지 못한 경우 두 개의 빈 문자열과 원래의 문자열을 포함하는 3-튜플을 반환합니다.sep 은 비어 있어서는 안 됩니다.
에러 시, 예외를 설정하고
NULL을 반환합니다.str.rpartition()과 동일합니다.
-
PyObject *PyUnicode_Join(PyObject *separator, PyObject *seq)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
주어진 separator를 사용하여 문자열 시퀀스를 연결하고 결과 유니코드 문자열을 반환합니다.
-
Py_ssize_t PyUnicode_Tailmatch(PyObject *unicode, PyObject *substr, Py_ssize_t start, Py_ssize_t end, int direction)¶
- …의 일부 안정 ABI.
substr이 주어진 꼬리 끝에서 (direction ==
-1은 접두사 일치를 수행함을 의미하고, direction ==1은 접미사 일치를 의미합니다)unicode[start:end]와 일치하면1을 반환합니다, 그렇지 않으면0을 반환합니다. 에러가 발생하면-1을 반환합니다.
-
Py_ssize_t PyUnicode_Find(PyObject *unicode, PyObject *substr, Py_ssize_t start, Py_ssize_t end, int direction)¶
- …의 일부 안정 ABI.
주어진 direction을 사용하여 (direction ==
1은 정방향 검색을 의미하고, direction ==-1은 역방향 검색을 의미합니다)unicode[start:end]에서 substr의 첫 번째 위치를 반환합니다. 반환 값은 첫 번째 일치의 인덱스입니다;-1값은 일치하는 항목이 없음을 나타내고,-2는 에러가 발생했고 예외가 설정되었음을 나타냅니다.
-
Py_ssize_t PyUnicode_FindChar(PyObject *unicode, Py_UCS4 ch, Py_ssize_t start, Py_ssize_t end, int direction)¶
- …의 일부 안정 ABI 버전 3.7 이후로.
주어진 direction을 사용하여 (direction ==
1은 정방향 검색을 의미하고, direction ==-1은 역방향 검색을 의미합니다)unicode[start:end]에서 문자 ch의 첫 번째 위치를 반환합니다. 반환 값은 첫 번째 일치의 인덱스입니다;-1값은 일치하는 항목이 없음을 나타내고,-2는 에러가 발생했고 예외가 설정되었음을 나타냅니다.Added in version 3.3.
버전 3.7에서 변경: start와 end는 이제
unicode[start:end]처럼 작동하도록 조정됩니다.
-
Py_ssize_t PyUnicode_Count(PyObject *unicode, PyObject *substr, Py_ssize_t start, Py_ssize_t end)¶
- …의 일부 안정 ABI.
unicode[start:end]에서 substr이 겹치지 않게 등장하는 횟수를 반환합니다. 에러가 발생하면-1을 반환합니다.
-
PyObject *PyUnicode_Replace(PyObject *unicode, PyObject *substr, PyObject *replstr, Py_ssize_t maxcount)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
unicode에서 substr의 최대 maxcount 등장을 replstr로 바꾸고 결과 유니코드 객체를 반환합니다. maxcount ==
-1은 모든 등장을 교체함을 의미합니다.
-
int PyUnicode_Compare(PyObject *left, PyObject *right)¶
- …의 일부 안정 ABI.
두 문자열을 비교하고 각각 작음, 같음, 큼에 대해
-1,0,1을 반환합니다.이 함수는 실패 시
-1을 반환하므로, 에러를 확인하기 위해PyErr_Occurred()를 호출해야 합니다.더 보기
PyUnicode_Equal()함수입니다.
-
int PyUnicode_Equal(PyObject *a, PyObject *b)¶
- …의 일부 안정 ABI 버전 3.14 이후로.
두 문자열이 같은지 테스트합니다:
a 와 b 가 같으면
1을 반환합니다.a 와 b 가 다르면
0을 반환합니다.
a 와 b 가
str객체인 경우 이 함수는 항상 성공합니다.이 함수는
str하위 클래스에 대해서도 작동하지만, 사용자 정의 __eq__() 메서드는 따르지 않습니다.더 보기
PyUnicode_Compare()함수입니다.Added in version 3.14.
-
int PyUnicode_EqualToUTF8AndSize(PyObject *unicode, const char *string, Py_ssize_t size)¶
- …의 일부 안정 ABI 버전 3.13 이후로.
유니코드 객체 unicode 를 string 과 비교하여 각각 작음, 같음, 큼에 대해
-1,0,1을 반환합니다. ASCII로 인코딩된 문자열만 전달하는 것이 가장 좋으나, 비 ASCII 문자가 포함된 경우 함수는 입력 문자열을 ISO-8859-1로 해석합니다.이 함수는 예외를 발생시키지 않습니다.
Added in version 3.13.
-
int PyUnicode_EqualToUTF8(PyObject *unicode, const char *string)¶
- …의 일부 안정 ABI 버전 3.13 이후로.
PyUnicode_EqualToUTF8AndSize()와 유사하지만,strlen()을 사용하여 string 길이를 계산합니다. 유니코드 객체가 널 문자를 포함하면, 거짓(0)을 반환합니다.Added in version 3.13.
-
int PyUnicode_CompareWithASCIIString(PyObject *unicode, const char *string)¶
- …의 일부 안정 ABI.
유니코드 객체 unicode를 string과 비교하고 각각 작음, 같음, 큼에 대해
-1,0,1을 반환합니다. ASCII로 인코딩된 문자열만 전달하는 것이 가장 좋지만, 비 ASCII 문자가 포함되면 함수는 입력 문자열을 ISO-8859-1로 해석합니다.이 함수는 예외를 발생시키지 않습니다.
-
PyObject *PyUnicode_RichCompare(PyObject *left, PyObject *right, int op)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
두 유니코드 문자열을 풍부한 비교(rich comparison) 하고 다음 중 하나를 반환합니다:
예외가 발생하면
NULL형 조합을 알 수 없으면
Py_NotImplemented
-
PyObject *PyUnicode_Format(PyObject *format, PyObject *args)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
format과 args에서 새 문자열 객체를 반환합니다; 이것은
format % args와 유사합니다.
-
int PyUnicode_Contains(PyObject *unicode, PyObject *substr)¶
- …의 일부 안정 ABI.
substr가 unicode에 포함되어 있는지 확인하고 그에 따라 참이나 거짓을 반환합니다.
substr는 단일 요소 유니코드 문자열로 강제 변환해야 합니다. 에러가 있으면
-1이 반환됩니다.
-
void PyUnicode_InternInPlace(PyObject **p_unicode)¶
- …의 일부 안정 ABI.
인자 *p_unicode를 제자리에서 인턴(intern) 합니다. 인자는 파이썬 유니코드 문자열을 가리키는 포인터 변수의 주소여야 합니다. *p_unicode와 같은 기존 인턴 문자열이 있으면, *p_unicode를 그것으로 설정합니다 (이전 문자열 객체에 대한 참조를 해제하고 인턴 된 문자열 객체에 대한 새로운 강한 참조를 만듭니다), 그렇지 않으면 *p_unicode만 홀로 두고 인턴 합니다.
(설명: 참조에 대해 많은 이야기가 있지만, 이 함수를 참조 중립이라고 생각하십시오. 전달하는 객체의 소유권을 반드시 가져야 합니다; 호출 후 더는 전달된 참조를 소유하지 않지만, 결과를 새로 소유하게 됩니다.)
이 함수는 예외를 발생시키지 않습니다. 오류 발생 시, 인자를 내부화(interning)하지 않고 그대로 유지합니다.
str하위 클래스의 인스턴스는 내부화될 수 없으며, 즉 PyUnicode_CheckExact(*p_unicode) 가 참이어야 합니다. 그렇지 않은 경우 다른 오류와 마찬가지로 인자는 변경되지 않은 채로 유지됩니다.인턴된 문자열이 “불멸(immortal)” 상태가 아님에 유의하십시오. 인턴의 이점을 얻으려면 결과에 대한 참조를 유지해야 합니다.
-
PyObject *PyUnicode_InternFromString(const char *str)¶
- 반환값: 새 참조. …의 일부 안정 ABI.
PyUnicode_FromString()과PyUnicode_InternInPlace()의 조합, 정적 할당된 문자열을 위한 것입니다.인턴(intern) 된 새 유니코드 문자열 객체나, 같은 값을 가진 이전에 인턴 된 문자열 객체에 대한 새 (“소유된”) 참조를 반환합니다.
Python may keep a reference to the result, or make it immortal, preventing it from being garbage-collected promptly. For interning an unbounded number of different strings, such as ones coming from user input, prefer calling
PyUnicode_FromString()andPyUnicode_InternInPlace()directly.
PyUnicodeWriter¶
PyUnicodeWriter API를 사용하여 파이썬 str 객체를 생성할 수 있습니다.
Added in version 3.14.
-
type PyUnicodeWriter¶
유니코드 라이터 인스턴스.
성공 시에는
PyUnicodeWriter_Finish()로, 오류 시에는PyUnicodeWriter_Discard()로 인스턴스를 파괴해야 합니다.
-
PyUnicodeWriter *PyUnicodeWriter_Create(Py_ssize_t length)¶
유니코드 라이터 인스턴스를 생성합니다.
length 는
0보다 크거나 같아야 합니다.length 가
0보다 크면, length 만큼의 문자를 담을 내부 버퍼를 미리 할당합니다.오류 발생 시 예외를 설정하고
NULL을 반환합니다.
-
PyObject *PyUnicodeWriter_Finish(PyUnicodeWriter *writer)¶
최종 파이썬
str객체를 반환하고 라이터 인스턴스를 파괴합니다.오류 발생 시 예외를 설정하고
NULL을 반환합니다.이 호출 이후에는 라이터 인스턴스가 유효하지 않습니다.
-
void PyUnicodeWriter_Discard(PyUnicodeWriter *writer)¶
내부 유니코드 버퍼를 버리고 라이터 인스턴스를 파괴합니다.
writer 가
NULL인 경우 아무런 작업도 수행되지 않습니다.이 호출 이후에는 라이터 인스턴스가 유효하지 않습니다.
-
int PyUnicodeWriter_WriteChar(PyUnicodeWriter *writer, Py_UCS4 ch)¶
writer 에 단일 유니코드 문자 ch 를 씁니다.
성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.
-
int PyUnicodeWriter_WriteUTF8(PyUnicodeWriter *writer, const char *str, Py_ssize_t size)¶
str 을 엄격한 모드로 UTF-8에서 디코딩하고 그 결과를 writer 에 씁니다.
size 는 바이트 단위의 문자열 길이입니다. size 가
-1인 경우,strlen(str)을 호출하여 문자열 길이를 가져옵니다.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.PyUnicodeWriter_DecodeUTF8Stateful()도 참조하십시오.
-
int PyUnicodeWriter_WriteASCII(PyUnicodeWriter *writer, const char *str, Py_ssize_t size)¶
str 에 있는 ASCII 문자열을 writer 에 씁니다.
size 는 바이트 단위의 문자열 길이입니다. size 가
-1인 경우,strlen(str)을 호출하여 문자열 길이를 가져옵니다.str 은 ASCII 문자만 포함해야 합니다. str 이 ASCII 이외의 문자를 포함하는 경우 동작이 정의되지 않습니다.
성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.
-
int PyUnicodeWriter_WriteWideChar(PyUnicodeWriter *writer, const wchar_t *str, Py_ssize_t size)¶
str 에 있는 와이드 문자열을 writer 에 씁니다.
size 는 와이드 문자 수입니다. size 가
-1인 경우,wcslen(str)를 호출하여 문자열 길이를 가져옵니다.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.
-
int PyUnicodeWriter_WriteUCS4(PyUnicodeWriter *writer, const Py_UCS4 *str, Py_ssize_t size)¶
str 에 있는 UCS4 문자열을 writer 에 씁니다.
size 는 UCS4 문자 수입니다.
성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.
-
int PyUnicodeWriter_WriteStr(PyUnicodeWriter *writer, PyObject *obj)¶
obj 에 대해
PyObject_Str()을 호출하고 결과를 writer 에 씁니다.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.__str__()메서드를 재정의한str하위 클래스를 쓰려면,PyUnicode_FromObject()를 사용하여 원본 문자열을 가져올 수 있습니다.
-
int PyUnicodeWriter_WriteRepr(PyUnicodeWriter *writer, PyObject *obj)¶
obj 에 대해
PyObject_Repr()를 호출하고 결과를 writer 에 씁니다.obj 이
NULL인 경우, writer 에"<NULL>"문자열을 씁니다.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.버전 3.14.4에서 변경:
NULL지원을 추가했습니다.
-
int PyUnicodeWriter_WriteSubstring(PyUnicodeWriter *writer, PyObject *str, Py_ssize_t start, Py_ssize_t end)¶
str 의 부분 문자열인
str[start:end]를 writer 에 씁니다.str must be Python
strobject. start must be greater than or equal to 0, and less than or equal to end. end must be less than or equal to str length.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.
-
int PyUnicodeWriter_Format(PyUnicodeWriter *writer, const char *format, ...)¶
PyUnicode_FromFormat()과 유사하지만, 결과를 writer 에 직접 기록합니다.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.
-
int PyUnicodeWriter_DecodeUTF8Stateful(PyUnicodeWriter *writer, const char *string, Py_ssize_t length, const char *errors, Py_ssize_t *consumed)¶
errors 오류 처리기를 사용하여 str 를 UTF-8에서 디코딩하고 결과를 writer 에 씁니다.
size 는 바이트 단위의 문자열 길이입니다. size 가
-1인 경우,strlen(str)을 호출하여 문자열 길이를 가져옵니다.errors 는
"replace"와 같은 error handler 이름입니다. errors 가NULL인 경우 엄격한 오류 처리기를 사용합니다.consumed 가
NULL이 아니면 성공 시 *consumed 를 디코딩된 바이트 수로 설정합니다. consumed 가NULL인 경우 후행의 불완전한 UTF-8 바이트 시퀀스를 오류로 처리합니다.성공 시
0을 반환합니다. 오류 시 예외를 설정하고 라이터를 변경하지 않은 채-1을 반환합니다.PyUnicodeWriter_WriteUTF8()도 참조하십시오.
더 이상 사용되지 않는 API (Deprecated)¶
다음 API는 더 이상 권장되지 않습니다(deprecated).
-
type Py_UNICODE¶
이것은 플랫폼에 따라 16비트 또는 32비트 타입인
wchar_t의 typedef입니다. 대신wchar_t를 직접 사용하십시오.버전 3.3에서 변경: 이전 버전에서, 이것은 빌드 시 파이썬의 “내로우(narrow)”나 “와이드(wide)” 유니코드 버전 중 어느 것을 선택했는지에 따라 16비트 형이나 32비트 형이었습니다.
버전 3.13부터 사용 지원 중단(deprecated), 버전 3.16에서 제거됨.
-
int PyUnicode_READY(PyObject *unicode)¶
아무것도 하지 않고
0을 반환합니다. 이 API는 하위 호환성을 위해서만 유지되며 제거 계획은 없습니다.Added in version 3.3.
버전 3.10부터 폐지됨: 이 API는 파이썬 3.12부터 아무것도 하지 않습니다. 이전에는 이전 API(
PyUnicode_FromUnicode()또는 유사한 기능)를 사용하여 생성된 각 문자열에 대해 호출해야 했습니다.
-
unsigned int PyUnicode_IS_READY(PyObject *unicode)¶
아무것도 하지 않고
1을 반환합니다. 이 API는 하위 호환성을 위해서만 유지되며 제거 계획은 없습니다.Added in version 3.3.
버전 3.14부터 폐지됨: 이 API는 파이썬 3.12부터 아무것도 하지 않습니다. 이전에는
PyUnicode_READY()가 필요한지 확인하기 위해 호출될 수 있었습니다.