go类型转换

Python023

go类型转换,第1张

type_name(expression)float跟int可以互转,但是会丢失所有精度。func AppendBool(dst []byte, b bool) []byteAppendBool 根据 b 的值将“true”或“false”附加到 dst 并返回扩展缓冲区。func AppendFloat(dst []byte, f float64, fmt byte, prec, bitSize int) []byteAppendFloat 将由 FormatFloat 生成的浮点数 f 的字符形式附加到 dst 并返回扩展缓冲区。func AppendInt(dst []byte, i int64, base int) []byteAppendInt 将由 FormatInt 生成的整数i的字符串形式附加到 dst 并返回扩展缓冲区。func AppendQuote(dst []byte, s string) []byteAppendQuote 将由 Quote 生成的代表 s 的双引号 Go 字符串文字附加到 dst 并返回扩展缓冲区。func AppendQuoteRune(dst []byte, r rune) []byteAppendQuoteRune 将由 QuoteRune 生成的表示符文的单引号 Go 字符文字附加到 dst 并返回扩展缓冲区。func AppendQuoteRuneToASCII(dst []byte, r rune) []byteAppendQuoteRuneToASCII 将由 QuoteRuneToASCII 生成的代表该符文的单引号 Go 字符文字附加到 dst 并返回扩展缓冲区。func AppendQuoteRuneToGraphic(dst []byte, r rune) []byteAppendQuoteRuneToGraphic 将由 QuoteRuneToGraphic 生成的表示符文的单引号 Go 字符文字附加到 dst 并返回扩展缓冲区。func AppendQuoteToASCII(dst []byte, s string) []byteAppendQuoteToASCII 将由 QuoteToASCII 生成的代表 s 的双引号 Go 字符串文字附加到 dst 并返回扩展缓冲区。func AppendQuoteToGraphic(dst []byte, s string) []byteAppendQuoteToGraphic 将由 QuoteToGraphic 生成的代表 s 的双引号 Go 字符串文字附加到 dst 并返回扩展缓冲区。func AppendUint(dst []byte, i uint64, base int) []byteAppendUint 将由 FormatUint 生成的无符号整数 i 的字符串形式附加到 dst 并返回扩展缓冲区。func Atoi(s string) (int, error)Atoi 返回 ParseInt(s, 10, 0) 转换为 int 类型的结果。func CanBackquote(s string) boolCanBackquote 报告字符串 s 是否可以不改变为单行反引号字符串,而不包含 tab 以外的控制字符。func FormatBool(b bool) stringFormatBool 根据 b 的值返回“true”或“false”func FormatFloat(f float64, fmt byte, prec, bitSize int) stringFormatFloat 根据格式 fmt 和 precision prec 将浮点数f转换为字符串。它将结果进行四舍五入,假设原始数据是从 bitSize 位的浮点值获得的(float32为32,float64为64)。 格式 fmt 是 'b'(-ddddp±ddd,二进制指数),'e'(-d.dddde±dd,十进制指数),'E'(-d.ddddE±dd,十进制指数),'f'(-ddd.dddd,无指数),'g'('e'表示大指数,'f'表示否则)或 'G'('E'表示大指数,否则'f')。 precision prec 控制由 'e','E','f','g' 和 'G' 格式打印的位数(不包括指数)。对于 'e','E' 和 'f',它是小数点后的位数。对于 'g' 和 'G' 这是总位数。特殊精度-1使用必需的最小位数,以便 ParseFloat 完全返回 f 。func FormatInt(i int64, base int) stringFormatInt 返回给定基数中的i的字符串表示,对于2 <= base <= 36.结果对于数字值>= 10使用小写字母 'a' 到 'z' 。func FormatUint(i uint64, base int) stringFormatUint 返回给定基数中的 i 的字符串表示,对于2 <= base <= 36.结果对于数字值>= 10使用小写字母 'a' 到 'z' 。func IsGraphic(r rune) boolIsGraphic 报告符文是否被 Unicode 定义为 Graphic。这些字符包括类别 L,M,N,P,S 和 Z 中的字母,标记,数字,标点,符号和空格。func IsPrint(r rune) boolIsPrint 报告该符文是否被 Go 定义为可打印,其定义与 unicode.IsPrint 相同:字母,数字,标点,符号和 ASCII 空格。func Itoa(i int) stringItoa 是 FormatInt(int64(i), 10) 的缩写。func ParseBool(str string) (bool, error)ParseBool 返回字符串表示的布尔值。它接受1,t,T,TRUE,true,True,0,f,F,FALSE,false,False。任何其他值都会返回错误。func ParseFloat(s string, bitSize int) (float64, error)ParseFloat 将字符串 s 转换为浮点数,精度由 bitSize:32指定,float32为64float64为64。当 bitSize = 32时,结果仍然具有 float64 类型,但可以在不更改其值的情况下将其转换为 float32。 如果s格式良好且接近有效的浮点数,则 ParseFloat 返回使用 IEEE754 无偏舍入舍入的最近浮点数。 ParseFloat 返回的错误具有具体类型 * NumError 并包含 err.Num = s。 如果 s 在语法上不是格式良好的,ParseFloat 返回 err.Err = ErrSyntax。 如果 s 在语法上格式良好,但距离给定大小的最大浮点数大于1/2 ULP,则 ParseFloat 返回 f =±Inf,err.Err = ErrRange。func ParseInt(s string, base int, bitSize int) (i int64, err error)ParseInt 解释给定基础(2到36)中的字符串 s 并返回相应的值 i。如果 base == 0,则基数由字符串的前缀隐含:base 16代表“0x”,base 8代表“0”,否则以10为底数。 bitSize 参数指定结果必须适合的整数类型。位大小 0,8,16,32 和 64 对应于 int,int8,int16,int32 和 int64。 ParseInt 返回的错误具有具体类型 * NumError 并包含err.Num = s。如果s为空或包含无效数字,则 err.Err = ErrSyntax,返回值为0如果与s对应的值不能用给定大小的有符号整数表示,则 err.Err = ErrRange,返回的值是相应 bitSize 和符号的最大幅度整数。func ParseUint(s string, base int, bitSize int) (uint64, error)ParseUint 就像 ParseInt,但是对于无符号数字。func Quote(s string) stringQuote 返回一个双引号的 Go 字符串字面表示s。返回的字符串使用 Go 转义序列 (\t, \n, \xFF, \u0100) 作为 IsPrint 定义的控制字符和非可打印字符。func QuoteRune(r rune) stringQuoteRune 返回一个表示符文的单引号 Go 字符。返回的字符串使用 Go 转义序列(\t, \n, \xFF, \u0100) 作为 IsPrint 定义的控制字符和非可打印字符。func QuoteRuneToASCII(r rune) stringQuoteRuneToASCII 返回表示符文的单引号 Go 字符。对于非 ASCII 字符和 IsPrint 定义的非可打印字符,返回的字符串使用 Go 转义序列 (\t, \n, \xFF, \u0100)。func QuoteRuneToGraphic(r rune) stringQuoteRuneToGraphic 返回代表符文的单引号 Go 字符。对于非 ASCII 字符和 IsGraphic 定义的非可打印字符,返回的字符串使用Go转义序列 (\t, \n, \xFF, \u0100)。func QuoteToASCII(s string) stringQuoteToASCII 返回一个代表 s 的双引号 Go 字符串。对于非 ASCII 字符和 IsPrint 定义的非可打印字符,返回的字符串使用 Go 转义序列 (\t, \n, \xFF, \u0100) 。func QuoteToGraphic(s string) stringQuoteToGraphic 返回一个代表 s 的双引号 Go 字符串。对于非 ASCII 字符和 IsGraphic 定义的非可打印字符,返回的字符串使用 Go 转义序列 (\t, \n, \xFF, \u0100)。func Unquote(s string) (string, error)Unquote 将 s 解释为单引号,双引号或反引号的 Go 字符串文字,返回引用的字符串值。(如果 s 是单引号,它将是一个 Go 字符字面量; Unquote 会返回相应的一个字符字符串。)

可以使用库函数atof。

1 函数名 atof

2 声明

double atof(const char *nptr)

3 头文件

#include <stdlib.h>

4 功能

将参数nptr中的字符串转为浮点型数据并返回。

5 需要注意的是,必须是合法的字符串,即以实数形式或者科学计数法形式存储的字符串才可以进行转换,否则转换会出错。 比如"sjdhk"这样的字符串是无法转换为浮点数的。而如果是"1.23sdf"这样的形式,只会处理到最后一个数字,结果为1.23。

5 示例代码

#include<stdlib.h>

int main()

{

char*a="-100.23"//实数形式存储的字符串

char*b="200e-2"//科学计数法形式存储的字符串

double c

c=atof(a)+atof(b)//转换后为 -100.23+200e-2=-100.23+2=-98.23

printf(“c=%.2lf\n”,c)//输出结果,保留2位小数。期望结果为c=-98.23

return 0

}