C++ Builder 參考手冊 ? System::Sysutils ? TextPos
獲取一個字符串出現(xiàn)在另一個字符串中的位置副渴,不區(qū)分大小寫
頭文件:#include <System.SysUtils.hpp>
命名空間:System::Sysutils
函數(shù)原型:
char *__fastcall TextPos(char *Str, char *SubStr);
System::WideChar *__fastcall TextPos(System::WideChar *Str, System::WideChar *SubStr);
參數(shù):
- Str:要獲取 Substr 這個字符串出現(xiàn)在 Str 中的位置奈附;
- Substr:要獲取 Substr 這個字符串出現(xiàn)在 Str 中的位置;
返回值:
- 如果字符串 Str 里面包含了字符串 Substr煮剧,返回的指針直接指向 Str 里面 Substr 所在的位置斥滤,英文字母不區(qū)分大小寫,如果要得到是第幾個 WideChar勉盅,需要把返回值減去 Str 得到整數(shù)序號值佑颇,例如 L"玄坴" 在 L"你好玄坴!" 的第 2 個 WideChar 位置 (0:你草娜,1:好挑胸,2:玄,3:坴宰闰,4:茬贵!);
- 如果字符串 S 里面不包含字符串 Substr移袍,返回值為 nullptr解藻;
- 參數(shù) Str 和 Substr 可以是空字符串 L"",但不可以是空指針 nullptr葡盗;
- 函數(shù)內(nèi)部實(shí)現(xiàn)是通過 StrLower 把 Str 和 SubStr 轉(zhuǎn)為小寫舆逃,再用 StrPos 查找的位置;
- UNICODE 版本的 TextPos 始終能夠得到正確結(jié)果;
- ANSI 版本的 TextPos 不檢查編碼路狮,只是按照每個 char 值是否相同虫啥,所以可能會找到半個漢字這樣的錯誤;
- UNICODE 版本的函數(shù)為目前使用的函數(shù)奄妨,ANSI 版本的函數(shù)由于編碼原因視為過時的函數(shù)涂籽。
相關(guān):
- System::Sysutils::AnsiPos
- System::Sysutils::AnsiStrPos
- System::Sysutils::StrPos
- System::Sysutils::TextPos
- System::Sysutils::StrScan
- System::Sysutils::StrRScan
- System::Sysutils::AnsiLastChar
- System::Sysutils::AnsiStrLastChar
- System::Sysutils::NextCharIndex
- System::Sysutils
- std::strstr, std::_fstrstr, std::_tcsstr, std::wcsstr
- std::strchr, std::_fstrchr, std::_tcschr, std::wcschr
- std::strrchr, std::_fstrrchr, std::_tcsrchr, std::wcsrchr
- std::_strspnp, std::_tcsspnp, std::_wcsspnp
- std::strcspn, std::_fstrcspn, std::_tcscspn, std::wcscspn
- std::strtok, std::_fstrtok, std::_tcstok, std::wcstok
- <cstring>
C++ Builder 參考手冊 ? System::Sysutils ? TextPos