字串轉換與格式化¶
用於數字轉換和格式化字串輸出的函式。
- intPyOS_snprintf(char*str,size_tsize,constchar*format,...)¶
- 為穩定 ABI 的一部分.
根據格式字串format 和額外引數,輸出不超過size 位元組給str。請參閱 Unix 使用手冊snprintf(3)。
- intPyOS_vsnprintf(char*str,size_tsize,constchar*format,va_listva)¶
- 為穩定 ABI 的一部分.
根據格式字串format 和變數引數串列va,輸出不超過size 位元組給str。Unix 使用手冊vsnprintf(3)。
PyOS_snprintf() 和PyOS_vsnprintf() 包裝標準 C 函式庫函式snprintf() 和vsnprintf()。它們的目的是確保邊角案例 (corner case) 下的行為一致,而標準 C 函式則不然。
包裝器確保回傳時str[size-1] 始終為'\0'。他們永遠不會在 str 中寫入超過size 位元組(包括尾隨的'\0')。這兩個函式都要求str!=NULL、size>0、format!=NULL 和size<INT_MAX。請注意,這表示沒有與 C99n=snprintf(NULL,0,...) 等效的函式來決定必要的緩衝區大小。
這些函式的回傳值 (rv) 應如下被直譯:
當
0<=rv<size時,輸出轉換成功,rv 字元被寫入str(不包括str[rv]處的尾隨'\0'位元組)。當
rv>=size時,輸出轉換被截斷,並且需要具有rv+1位元組的緩衝區才能成功。在這種情況下,str[size-1]是'\0'。當
rv<0時,代表輸出的轉換失敗,且在這種情況下str[size-1]也是'\0',但str 的其餘部分未定義。錯誤的確切原因取決於底層平台。
以下函式提供與區域設定無關 (locale-independent) 的字串到數字的轉換。
- unsignedlongPyOS_strtoul(constchar*str,char**ptr,intbase)¶
- 為穩定 ABI 的一部分.
將字串
str的初始部分根據給定的base轉換為unsignedlong 值,底 (base) 必須介於2到36(包含)之間,或為特殊值0。忽略前導空白和字元大小寫。如果
base為零,則會尋找前導的0b、0o或0x來判斷使用哪個進位。如果這些前綴不存在,則預設為10。底必須為 0 或介於 2 到 36(包含)之間。如果ptr為非NULL,它將包含指向掃描結束處的指標。如果轉換後的值超出對應回傳型別的範圍,則會發生範圍錯誤(
errno會被設定為ERANGE)並回傳ULONG_MAX。如果無法執行任何轉換,則回傳0。也請見 Unix 使用手冊strtoul(3)。
在 3.2 版被加入.
- longPyOS_strtol(constchar*str,char**ptr,intbase)¶
- 為穩定 ABI 的一部分.
將字串
str的初始部分根據給定的base轉換為long 值,底 必須介於2到36(包含)之間,或為特殊值0。與
PyOS_strtoul()相同,但回傳long 值,並在溢位時回傳LONG_MAX。也請見 Unix 使用手冊strtol(3)。
在 3.2 版被加入.
- doublePyOS_string_to_double(constchar*s,char**endptr,PyObject*overflow_exception)¶
- 為穩定 ABI 的一部分.
將字串
s轉換為double,失敗時引發 Python 例外。接受的字串集合對應於 Python 的float()建構函式接受的字串集合,但s不得有前導或尾隨的空格。轉換與目前區域設定無關。如果
endptr為NULL,則轉換整個字串。如果字串不是浮點數的有效表示,則引發ValueError並回傳-1.0。如果 endptr 不是
NULL,則盡可能轉換字串,並將*endptr設定為指向第一個未轉換的字元。如果字串的初始片段都不是浮點數的有效表示,則設定*endptr指向字串的開頭,引發 ValueError 並回傳-1.0。如果
s表示的值太大而無法儲存在浮點數中(例如"1e500"在許多平台上都是這樣的字串),如果overflow_exception為NULL則回傳Py_INFINITY(會帶有適當的符號)並且不設定任何例外。否則,overflow_exception必須指向一個 Python 例外物件;引發該例外並回傳-1.0。在這兩種情況下,將*endptr設定為指向轉換後的值之後的第一個字元。如果轉換期間發生任何其他錯誤(例如記憶體不足的錯誤),請設定適當的 Python 例外並回傳
-1.0。在 3.1 版被加入.
- char*PyOS_double_to_string(doubleval,charformat_code,intprecision,intflags,int*ptype)¶
- 為穩定 ABI 的一部分.
使用提供的format_code、precision 和flags 將doubleval 轉換為字串。
format_code 必須是
'e'、'E'、'f'、'F'、'g'、'G'或'r'其中之一。對於'r',提供的precision 必須為 0 並會被忽略。'r'格式碼指定標準repr()格式。flags 可以是零個或多個以下的值被聯集在一起:
- Py_DTSF_SIGN¶
總是在回傳的字串前面加上正負號字元 (sign character),即使val 非負數。
- Py_DTSF_ADD_DOT_0¶
確保回傳的字串看起來不會像整數。
- Py_DTSF_ALT¶
套用「備用的 (alternate)」格式化規則。有關詳細資訊,請參閱
PyOS_snprintf()'#'的文件。
- Py_DTSF_NO_NEG_0¶
負零會被轉換為正零。
在 3.11 版被加入.
如果ptype 是非
NULL,那麼它指向的值將被設定為Py_DTST_FINITE、Py_DTST_INFINITE或Py_DTST_NAN其中之一,分別代表val 是有限數、無限數或非數。回傳值是指向buffer 的指標,其中包含轉換後的字串,如果轉換失敗則回傳
NULL。呼叫者負責透過呼叫PyMem_Free()來釋放回傳的字串。在 3.1 版被加入.
- Py_DTSF_SIGN¶
- intPyOS_stricmp(constchar*s1,constchar*s2)¶
不區分大小寫的字串比較。函式的作用方式幾乎與
strcmp()相同,只是它忽略大小寫。
- intPyOS_strnicmp(constchar*s1,constchar*s2,Py_ssize_tsize)¶
不區分大小寫的字串比較。函式的作用方式幾乎與
strncmp()相同,只是它忽略大小寫。
Character classification and conversion¶
The following macros provide locale-independent (unlike the C standard libraryctype.h) character classification and conversion.The argument must be a signed or unsignedchar.
- Py_ISALNUM(c)¶
Return true if the characterc is an alphanumeric character.
- Py_ISALPHA(c)¶
Return true if the characterc is an alphabetic character (
a-zandA-Z).
- Py_ISDIGIT(c)¶
Return true if the characterc is a decimal digit (
0-9).
- Py_ISLOWER(c)¶
Return true if the characterc is a lowercase ASCII letter (
a-z).
- Py_ISUPPER(c)¶
Return true if the characterc is an uppercase ASCII letter (
A-Z).
- Py_ISSPACE(c)¶
Return true if the characterc is a whitespace character (space, tab,carriage return, newline, vertical tab, or form feed).
- Py_ISXDIGIT(c)¶
Return true if the characterc is a hexadecimal digit (
0-9,a-f, andA-F).
- Py_TOLOWER(c)¶
Return the lowercase equivalent of the characterc.
- Py_TOUPPER(c)¶
Return the uppercase equivalent of the characterc.