codec レジストリとサポート関数

int PyCodec_Register(PyObject *search_function)
次に属します: Stable ABI.

新しい codec 検索関数を登録します。

As a side effect, this tries to load the encodings package, if not yet done, to make sure that it is always first in the list of search functions.

int PyCodec_Unregister(PyObject *search_function)
次に属します: Stable ABI (バージョン 3.10 より).

コーデック検索関数の登録を解除し、レジストリのキャッシュをクリアします。 検索関数が登録されていない場合は何もしません。 成功したら0を返します。 エラーの場合は例外を送出させ、-1を返します。

Added in version 3.10.

int PyCodec_KnownEncoding(const char *encoding)
次に属します: Stable ABI.

encoding のための登録された codec が存在するかどうかに応じて 10 を返します。 この関数は常に成功します。

PyObject *PyCodec_Encode(PyObject *object, const char *encoding, const char *errors)
戻り値: 新しい参照。 次に属します: Stable ABI.

汎用の codec ベースの encode API.

encoding に応じて見つかったエンコーダ関数に対して object を渡します。 エラーハンドリングメソッドは errors で指定します。 errorsNULL でもよく、その場合はその codec のデフォルトのメソッドが利用されます。 エンコーダが見つからなかった場合は LookupError を発生させます。

PyObject *PyCodec_Decode(PyObject *object, const char *encoding, const char *errors)
戻り値: 新しい参照。 次に属します: Stable ABI.

汎用の codec ベースのデコード API.

object is passed through the decoder function found for the given encoding using the error handling method defined by errors. errors may be NULL to use the default method defined for the codec. Raises a LookupError if no decoder can be found.

コーデック検索API

次の関数では、文字列 encoding は全て小文字に変換することで、効率的に、大文字小文字を無視した検索をします。 コーデックが見つからない場合、 KeyError を設定して NULL を返します。

PyObject *PyCodec_Encoder(const char *encoding)
戻り値: 新しい参照。 次に属します: Stable ABI.

与えられた encoding のエンコーダ関数を返します。

PyObject *PyCodec_Decoder(const char *encoding)
戻り値: 新しい参照。 次に属します: Stable ABI.

与えられた encoding のデコーダ関数を返します。

PyObject *PyCodec_IncrementalEncoder(const char *encoding, const char *errors)
戻り値: 新しい参照。 次に属します: Stable ABI.

与えられた encodingIncrementalEncoder オブジェクトを返します。

PyObject *PyCodec_IncrementalDecoder(const char *encoding, const char *errors)
戻り値: 新しい参照。 次に属します: Stable ABI.

与えられた encodingIncrementalDecoder オブジェクトを返します。

PyObject *PyCodec_StreamReader(const char *encoding, PyObject *stream, const char *errors)
戻り値: 新しい参照。 次に属します: Stable ABI.

与えられた encodingStreamReader ファクトリ関数を返します。

PyObject *PyCodec_StreamWriter(const char *encoding, PyObject *stream, const char *errors)
戻り値: 新しい参照。 次に属します: Stable ABI.

与えられた encodingStreamWriter ファクトリ関数を返します。

Unicode エラーハンドラ用レジストリ API

int PyCodec_RegisterError(const char *name, PyObject *error)
次に属します: Stable ABI.

エラーハンドルのためのコールバック関数 errorname で登録します。このコールバック関数は、コーデックがエンコードできない文字/デコードできないバイトに遭遇した時に、そのエンコード/デコード関数の呼び出しで name が指定されていたら呼び出されます。

コールバックは1つの引数として、 UnicodeEncodeError, UnicodeDecodeError, UnicodeTranslateError のどれかのインスタンスを受け取ります。このインスタンスは問題のある文字列やバイト列に関する情報と、その元の文字列中のオフセットを持っています。(その情報を取得するための関数については Unicode 例外オブジェクト を参照してください。) コールバックは渡された例外を発生させるか、2要素のタプルに問題のシーケンスの代替と、 encode/decode を再開する元の文字列中のオフセットとなる整数を格納して返します。

成功したら 0 を、エラー時は -1 を返します。

PyObject *PyCodec_LookupError(const char *name)
戻り値: 新しい参照。 次に属します: Stable ABI.

name で登録されたエラーハンドリングコールバック関数を検索します。 特別な場合として、NULL が渡された場合、"strict" のエラーハンドリングコールバック関数を返します。

PyObject *PyCodec_StrictErrors(PyObject *exc)
戻り値: 常に NULL 。 次に属します: Stable ABI.

exc を例外として発生させます。

PyObject *PyCodec_IgnoreErrors(PyObject *exc)
戻り値: 新しい参照。 次に属します: Stable ABI.

unicode エラーを無視し、問題の入力をスキップします。

PyObject *PyCodec_ReplaceErrors(PyObject *exc)
戻り値: 新しい参照。 次に属します: Stable ABI.

unicode エラーを ?U+FFFD で置き換えます。

PyObject *PyCodec_XMLCharRefReplaceErrors(PyObject *exc)
戻り値: 新しい参照。 次に属します: Stable ABI.

unicode encode エラーを XML文字参照で置き換えます。

PyObject *PyCodec_BackslashReplaceErrors(PyObject *exc)
戻り値: 新しい参照。 次に属します: Stable ABI.

unicode encode エラーをバックスラッシュエスケープ (\x, \u, \U) で置き換えます。

PyObject *PyCodec_NameReplaceErrors(PyObject *exc)
戻り値: 新しい参照。 次に属します: Stable ABI (バージョン 3.7 より).

unicode encode エラーを \N{...} で置き換えます。

Added in version 3.5.

Codec utility variables

const char *Py_hexdigits

A string constant containing the lowercase hexadecimal digits: "0123456789abcdef".

Added in version 3.3.