详解Go strconv包
作者:云崖先生 发布时间:2024-04-23 09:42:08
strconv包
该包主要实现基本数据类型与其字符串表示的转换。
常用函数为Atoi()
、Itia()
、parse
系列、format
系列、append
系列。
更多函数请查看官方文档。
string与int类型转换
Atoi()
该函数用于将字符串类型的整数转换为int
类型,函数签名如下:
func Atoi(s string) (i int, err error)
如果传入的字符串参数无法转换为int类型,就会返回错误。
示例演示:
package main
import (
"fmt"
"strconv"
)
func main(){
strInt := "100"
num,err := strconv.Atoi(strInt)
if err != nil{
fmt.Println("can't convert to int",err)
return
}
fmt.Printf("type:%T\nvalue:%#v\n",num,num)
// type:int
// value:100
}
Itoa()
该函数用于将int
类型数据数据转换为对应的字符串表现形式,函数签名如下:
func Itoa(i int) string
示例代码如下:
package main
import (
"fmt"
"strconv"
)
func main(){
num := 100
strInt := strconv.Itoa(num)
fmt.Printf("type:%T\nvalue:%#v\n",strInt,strInt)
// type:string
// value:"100"
}
为什么不是s
可以注意到,不管是int
转string
还是string
转int
,都是使用a
代表字符串,使用i
代表int
类型的数据。为什么不用s
呢?这其实是C
语言中没有string
类型的原因,c
语言中用字符数组表示字符串。所以上面两个函数使用a
来表示字符串,即为array
的首字母。
Parse系列
Parse
类函数用于转换字符串为给定类型的值:ParseBool()
、ParseFloat()
、ParseInt()
、ParseUint()
。
ParseBool()
func ParseBool(str string) (value bool, err error)
返回字符串表示的bool
值。它只接受1、0、t、f、T、F、true、false、True、False、TRUE、FALSE;否则返回错误。
package main
import (
"fmt"
"strconv"
)
func main() {
result, _ := strconv.ParseBool("1")
fmt.Printf("type:%T\n value:%#v\n", result, result)
// type:bool
// value:true
}
ParseInt()
func ParseInt(s string, base int, bitSize int) (i int64, err error)
返回字符串表示的整数值,接受正负号。
base
指定进制(2到36),如果base
为0,则会从字符串前置判断,”0x”是16进制,”0”是8进制,否则是10进制;
bitSize
指定结果必须能无溢出赋值的整数类型,0、8、16、32、64 分别代表 int、int8、int16、int32、int64;
返回的err
是*NumErr
类型的,如果语法有误,err.Error = ErrSyntax;如果结果超出类型范围err.Error = ErrRange。
package main
import (
"fmt"
"strconv"
)
func main() {
// 返回10 , 十进制, 结果是int64
result, _ := strconv.ParseInt("127", 0, 64)
fmt.Printf("type:%T\n value:%#v\n", result, result)
// type:int64
// value:127
}
ParseUnit()
func ParseUint(s string, base int, bitSize int) (n uint64, err error)
ParseUint
类似ParseInt
但不接受正负号,用于无符号整型。
ParseFloat()
func ParseFloat(s string, bitSize int) (f float64, err error)
解析一个表示浮点数的字符串并返回其值。
如果s合乎语法规则,函数会返回最为接近s表示值的一个浮点数(使用IEEE754规范舍入)。
bitSize指定了期望的接收类型,32是float32(返回值可以不改变精确值的赋值给float32),64是float64;
返回值err是*NumErr类型的,语法有误的,err.Error=ErrSyntax;结果超出表示范围的,返回值f为±Inf,err.Error= ErrRange。
package main
import (
"fmt"
"strconv"
)
func main() {
result, _ := strconv.ParseFloat("3.1415", 64)
fmt.Printf("type:%T\n value:%#v\n", result, result)
// type:float64
// value:3.1415
}
Format系列
Format
系列函数实现了将给定类型数据格式化为string
类型数据的功能。
FormatBool()
func FormatBool(b bool) string
根据b的值返回true
或false
。
package main
import (
"fmt"
"strconv"
)
func main(){
result := strconv.FormatBool(true)
fmt.Printf("type:%T\n value:%#v\n",result,result)
// type:string
// value:"true"
}
FormatInt()
func FormatInt(i int64, base int) string
返回i的base
进制的字符串表示。base
必须在2到36之间,结果中会使用小写字母'a'到'z'表示大于10的数字。
package main
import (
"fmt"
"strconv"
)
func main() {
result := strconv.FormatInt(127, 2) // 二进制的字符串
fmt.Printf("type:%T\n value:%#v\n", result, result)
// type:string
// value:"1111111"
}
FormatUint()
func FormatUint(i uint64, base int) string
同上,但是不支持负数。
是FormatInt()
的无符号整数版本。
FormatFloat()
func FormatFloat(f float64, fmt byte, prec, bitSize int) string
函数将浮点数表示为字符串并返回。
bitSize表示f的来源类型(32:float32、64:float64),会据此进行舍入。
fmt表示格式:'f'(-ddd.dddd)、'b'(-ddddp±ddd,指数为二进制)、'e'(-d.dddde±dd,十进制指数)、'E'(-d.ddddE±dd,十进制指数)、'g'(指数很大时用'e'格式,否则'f'格式)、'G'(指数很大时用'E'格式,否则'f'格式)。
prec控制精度(排除指数部分):对'f'、'e'、'E',它表示小数点后的数字个数;对'g'、'G',它控制总的数字个数。如果prec 为-1,则代表使用最少数量的、但又必需的数字来表示f。
package main
import (
"fmt"
"strconv"
)
func main() {
result := strconv.FormatFloat(3.1415, 'e', 2, 32) // 注意,第二参数为字符,并非字符串。单引号
fmt.Printf("type:%T\n value:%#v\n", result, result)
// type:string
// value:"3.14e+00"
}
来源:https://www.cnblogs.com/Yunya-Cnblogs/p/13805743.html
猜你喜欢
- 文章介绍了flask框架中的cookie和session。Session是在服务器端保存的一个数据结构,用来跟踪用户的状态,这个数据可以保存
- 1.Python3读取hdf文件最开始使用Python导入pyhdf包的时候是可以的,但是当导入pyhdf.SD的时候就出现了以下问题:我查
- numpy的delete是可以删除数组的整行和整列的,下面简单介绍和举例说明delete函数用法:numpy.delete(arr, obj
- 一、pycharm配置1、部署配置工具==》部署==》配置2、python解释器文件==》设置==》项目:xx==》python解释器3、运
- 本文研究的主要问题时Python读取word文本操作,分享了相关概念和实现代码,具体如下。一,docx模块Python可以利用python-
- 前言有时候大家需要知道一个关键词在互联网上的热度,想知道某个关键词的热度变化趋势。大家可能就是使用百度指数、微信指数之类的。非常好用,但是就
- 如果用树作为索引的数据结构,每查找一次数据就会从磁盘中读取树的一个节点,也就是一页,而二叉树的每个节点只存储一条数据,并不能填满一页的存储空
- 本文实例讲述了python简单获取数组元素个数的方法。分享给大家供大家参考。具体如下:mySeq = [1,2,3,4,5] p
- ThinkPHP CURD方法的limit方法也是模型类的连贯操作方法之一,主要用于指定查询和操作的数量,特别在分页查询的时候使用较多。并且
- 最近在pythonTip做题的时候,遇到了deque模块,以前对其不太了解,现在特此总结一下deque模块是python标准库collect
- display_errors 错误回显,一般常用语开发模式,但是很多应用在正式环境中也忘记了关闭此选项。错误回显可以暴露出非常多的敏感信息,
- 打包依赖文件至目标程序目录问题我使用 PySide2 开发了一个应用程序,为了方便其他人使用,我便使用 PyInstaller 打包成 *.
- <?php /*============================文件说明===========================
- 实现效果如下: 需求:由于后台搜索选项有很多,影响页面美观,所以一进来要隐藏一部分搜索项,只保留1行,点击【展开搜索】按钮的时候才
- 本文实例为大家分享了微信小程序实现搜索框功能的具体代码,供大家参考,具体内容如下效果:wxml文件:<view class="
- javascript 常见汉字转换成拼音,上下行排列,方便对比,速度快,你可以把代码复制到本地,作为一个不错的汉字转换拼音的工具!转换效果图
- 本节主要介绍函数,但是函数是由操作组成的。那么就分为两部,一部分为操作一部分为函数。py世界中的操作。操作if:在学习任何一门语言中,关系i
- 可编辑下拉框-HTML <div style="position:relative;"> <selec
- 误区 #7:一个数据库可以存在多个镜像 错误 这个误区就有点老生常谈了。每一个主体服务器只允许一个镜像服务器。如果你希望存在多个主体服务器的
- 这个decorator是什么意思呢?很简单,它接受一个log的参数,即传入logger对象。然后它会先把函数名打印出来,接下来,会利用enu