C裡面怎麼把字串轉成數字

2021-06-26 05:56:12 字數 4323 閱讀 5267

字串"123"轉成數字123 怎麼轉?
atof(將字串轉換成浮點型數)

相關函式 atoi,atol,strtod,strtol,strtoul

表頭檔案 #include 定義函式 double atof(const char *nptr);

函式說明 atof()會掃瞄引數nptr字串,跳過前面的空格字元,直到遇上數字或正負符號才開始做轉換,而再遇到非數字或字串結束時('\0')才結束轉換,並將結果返回。引數nptr字串可包含正負號、小數點或e(e)來表示指數部分,如123.456或123e-2。

返回值 返回轉換後的浮點型數。

附加說明 atof()與使用strtod(nptr,(char**)null)結果相同。

範例 /* 將字串a 與字串b轉換成數字後相加*/

#includemain()

執行 c=-98.23

atoi(將字串轉換成整型數)

相關函式 atof,atol,atrtod,strtol,strtoul

表頭檔案 #include定義函式 int atoi(const char *nptr);

函式說明 atoi()會掃瞄引數nptr字串,跳過前面的空格字元,直到遇上數字或正負符號才開始做轉換,而再遇到非數字或字串結束時('\0')才結束轉換,並將結果返回。

返回值 返回轉換後的整型數。

附加說明 atoi()與使用strtol(nptr,(char**)null,10);結果相同。

範例 /* 將字串a 與字串b轉換成數字後相加*/

#includemian()

執行 c=356

atol(將字串轉換成長整型數)

相關函式 atof,atoi,strtod,strtol,strtoul

表頭檔案 #include定義函式 long atol(const char *nptr);

函式說明 atol()會掃瞄引數nptr字串,跳過前面的空格字元,直到遇上數字或正負符號才開始做轉換,而再遇到非數字或字串結束時('\0')才結束轉換,並將結果返回。

返回值 返回轉換後的長整型數。

附加說明 atol()與使用strtol(nptr,(char**)null,10);結果相同。

範例 /*將字串a與字串b轉換成數字後相加*/

#includemain()

執行 c=1234567890

gcvt(將浮點型數轉換為字串,取四捨五入)

相關函式 ecvt,fcvt,sprintf

表頭檔案 #include定義函式 char *gcvt(double number,size_t ndigits,char *buf);

函式說明 gcvt()用來將引數number轉換成ascii碼字串,引數ndigits表示顯示的位數。gcvt()與ecvt()和fcvt()不同的地方在於,gcvt()所轉換後的字串包含小數點或正負符號。若轉換成功,轉換後的字串會放在引數buf指標所指的空間。

返回值 返回一字串指標,此位址即為buf指標。

附加說明

範例 #includemain()

執行 a value=123.45

b value=-1234.56

strtod(將字串轉換成浮點數)

相關函式 atoi,atol,strtod,strtol,strtoul

表頭檔案 #include定義函式 double strtod(const char *nptr,char **endptr);

函式說明 strtod()會掃瞄引數nptr字串,跳過前面的空格字元,直到遇上數字或正負符號才開始做轉換,到出現非數字或字串結束時('\0')才結束轉換,並將結果返回。若endptr不為null,則會將遇到不合條件而終止的nptr中的字元指標由endptr傳回。引數nptr字串可包含正負號、小數點或e(e)來表示指數部分。如123.456或123e-2。

返回值 返回轉換後的浮點型數。

範例 /*將字串a,b,c 分別採用10,2,16 進製轉換成數字*/

#includemian()

執行 a=1000000000

b=512

c=65535

strtol(將字串轉換成長整型數)

相關函式 atof,atoi,atol,strtod,strtoul

表頭檔案 #include定義函式 long int strtol(const char *nptr,char **endptr,int base);

函式說明 strtol()會將引數nptr字串根據引數base來轉換成長整型數。引數base範圍從2至36,或0。引數base代表採用的進製方式,如base值為10則採用10進製,若base值為16則採用16進製制等。當base值為0時則是採用10進製做轉換,但遇到如'0x'前置字元則會使用16進製做轉換。一開始strtol()會掃瞄引數nptr字串,跳過前面的空格字元,直到遇上數字或正負符號才開始做轉換,再遇到非數字或字串結束時('\0')結束轉換,並將結果返回。若引數endptr不為null,則會將遇到不合條件而終止的nptr中的字元指標由endptr返回。

返回值 返回轉換後的長整型數,否則返回erange並將錯誤**存入errno中。

附加說明 erange指定的轉換字串超出合法範圍。

範例 /* 將字串a,b,c 分別採用10,2,16進製制轉換成數字*/

#includemain()

執行 a=1000000000

b=512

c=65535

strtoul(將字串轉換成無符號長整型數)

相關函式 atof,atoi,atol,strtod,strtol

表頭檔案 #include定義函式 unsigned long int strtoul(const char *nptr,char **endptr,int base);

函式說明 strtoul()會將引數nptr字串根據引數base來轉換成無符號的長整型數。引數base範圍從2至36,或0。引數base代表採用的進製方式,如base值為10則採用10進製,若base值為16則採用16進製制數等。當base值為0時則是採用10進製做轉換,但遇到如'0x'前置字元則會使用16進製做轉換。一開始strtoul()會掃瞄引數nptr字串,跳過前面的空格字串,直到遇上數字或正負符號才開始做轉換,再遇到非數字或字串結束時('\0')結束轉換,並將結果返回。若引數endptr不為null,則會將遇到不合條件而終止的nptr中的字元指標由endptr返回。

返回值 返回轉換後的長整型數,否則返回erange並將錯誤**存入errno中。

附加說明 erange指定的轉換字串超出合法範圍。

範例 參考strtol()

toascii(將整型數轉換成合法的ascii 碼字元)

相關函式 isascii,toupper,tolower

表頭檔案 #include定義函式 int toascii(int c)

函式說明 toascii()會將引數c轉換成7位的unsigned char值,第八位則會被清除,此字元即會被轉成ascii碼字元。

返回值 將轉換成功的ascii碼字元值返回。

範例 #includemain()

執行 before toascii() : a value =217()

after toascii() : a value =89(y)

tolower(將大寫字母轉換成小寫字母)

相關函式 isalpha,toupper

表頭檔案 #include定義函式 int tolower(int c);

函式說明 若引數c為大寫字母則將該對應的小寫字母返回。

返回值 返回轉換後的小寫字母,若不須轉換則將引數c值返回。

附加說明

範例 /* 將s字串內的大寫字母轉換成小寫字母*/

#includemain()

{char s=」abcdefgh12345;!#$」;

int i;

printf(「before tolower() : %s\n」,s);

for(i=0;i定義函式 int toupper(int c);

函式說明 若引數c為小寫字母則將該對映的大寫字母返回。

返回值 返回轉換後的大寫字母,若不須轉換則將引數c值返回。

附加說明

範例 /* 將s字串內的小寫字母轉換成大寫字母*/

#includemain()

{char s=」abcdefgh12345;!#$」;

int i;

printf(「before toupper() : %s\n」,s);

for(i=0;i

mysql將字串轉成數字

今天寫sql語句時,相對字串型別的數字進行排序,怎麼做呢?需要先轉換成數字再進行排序 1.直接用加法 字串 0 eg select from orders order by mark 0 desc 2.使用函式 cast value as type convert value,type 注 這裡的t...

mysql將字串轉成數字

今天寫sql語句時,相對字串型別的數字進行排序,怎麼做呢?需要先轉換成數字再進行排序 1.直接用加法 字串 0 eg select from orders order by mark 0 desc eg 以分類字段進行分組,獲取分類總數amount,和qty 數量 最後以amount進行有大到小的倒...

把字串轉換成數字

寫乙個函式,實現把字串轉換成正數這個功能,不能使用atoi或者其他類似的庫函式。首先,該函式會根據需要丟棄無用的開頭空格字元,直至尋找到第乙個非空字元的字元為止。當我們尋找到的第乙個非空字元為正號或者負號時,則將該符號與之後盡可能多的連續數字組合起來,作為該正數的正負號,假如第乙個非空字元是數字,則...