第三篇 -- Go语言其他类型转String方法
1. int转string
// 法1: int转string
num_int := 10
num_str_2 := fmt.Sprintf("%b", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_2的数据类型是%T, num_str_2=%s\n", num_int, num_str_2, num_str_2)
num_str_8 := fmt.Sprintf("%o", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_8的数据类型是%T, num_str_8=%s\n", num_int, num_str_8, num_str_8)
num_str_10 := fmt.Sprintf("%d", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_10的数据类型是%T, num_str_10=%s\n", num_int, num_str_10, num_str_10)
num_str_16 := fmt.Sprintf("%0x", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_16的数据类型是%T, num_str_16=%s\n", num_int, num_str_16, num_str_16) // 法2: int转string
num1_int := 128
num1_str_2 := strconv.FormatInt(int64(num1_int), 2)
num1_str_8 := strconv.FormatInt(int64(num1_int), 8)
num1_str_10 := strconv.Itoa(num1_int)
num1_str_16 := strconv.FormatInt(int64(num1_int), 16)
fmt.Printf("num1_int的数据类型是%T, num1_str_2的数据类型是%T, num1_str_2=%s\n", num1_int, num1_str_2, num1_str_2)
fmt.Printf("num1_int的数据类型是%T, num1_str_8的数据类型是%T, num1_str_8=%s\n", num1_int, num1_str_8, num1_str_8)
fmt.Printf("num1_int的数据类型是%T, num1_str_10的数据类型是%T, num1_str_10=%s\n", num1_int, num1_str_10, num1_str_10)
fmt.Printf("num1_int的数据类型是%T, num1_str_16的数据类型是%T, num1_str_16=%s\n", num1_int, num1_str_16, num1_str_16)
输出结果为:
num_int的数据类型是int, num_str_2的数据类型是string, num_str_2=1010
num_int的数据类型是int, num_str_8的数据类型是string, num_str_8=12
num_int的数据类型是int, num_str_10的数据类型是string, num_str_10=10
num_int的数据类型是int, num_str_16的数据类型是string, num_str_16=a
num1_int的数据类型是int, num1_str_2的数据类型是string, num1_str_2=10000000
num1_int的数据类型是int, num1_str_8的数据类型是string, num1_str_8=200
num1_int的数据类型是int, num1_str_10的数据类型是string, num1_str_10=128
num1_int的数据类型是int, num1_str_16的数据类型是string, num1_str_16=80
2. float转string
// 法1: float转string
num_float := 12.75
num_str := fmt.Sprintf("%f", num_float)
fmt.Printf("num_float的数据类型是%T,num_str的数据类型是%T,num_str=%s\n", num_float, num_str, num_str)
num_str_k3 := fmt.Sprintf("%.3f", num_float)
fmt.Printf("num_float的数据类型是%T,num_str_k3的数据类型是%T,num_str_k3=%s\n", num_float, num_str_k3, num_str_k3)
num_str_k1 := fmt.Sprintf("%.1f", num_float)
fmt.Printf("num_float的数据类型是%T,num_str_k1的数据类型是%T,num_str_k1=%s\n", num_float, num_str_k1, num_str_k1) // 法2: float转string
num1_float := 128.99000003253
num1_str_k8 := strconv.FormatFloat(num1_float, 'f', 8, 64)
fmt.Printf("num1_float的数据类型是%T, num1_str_k8的数据类型是%T, num1_str_k8=%s\n", num1_float, num1_str_k8, num1_str_k8)
num1_str_k2 := strconv.FormatFloat(num1_float, 'f', 2, 64)
fmt.Printf("num1_float的数据类型是%T, num1_str_k2的数据类型是%T, num1_str_k2=%s\n", num1_float, num1_str_k2, num1_str_k2)
num1_str_k0 := strconv.FormatFloat(num1_float, 'f', 0, 64)
fmt.Printf("num1_float的数据类型是%T, num1_str_k0的数据类型是%T, num1_str_k0=%s\n", num1_float, num1_str_k0, num1_str_k0)
输出结果为:
num_float的数据类型是float64,num_str的数据类型是string,num_str=12.750000
num_float的数据类型是float64,num_str_k3的数据类型是string,num_str_k3=12.750
num_float的数据类型是float64,num_str_k1的数据类型是string,num_str_k1=12.8
num1_float的数据类型是float64, num1_str_k8的数据类型是string, num1_str_k8=128.99000003
num1_float的数据类型是float64, num1_str_k2的数据类型是string, num1_str_k2=128.99
num1_float的数据类型是float64, num1_str_k0的数据类型是string, num1_str_k0=129
3. bool转string
// 法1: bool转string
b_bool := true
b_str := fmt.Sprintf("%t", b_bool)
fmt.Printf("b_bool的数据类型是%T, b_str的数据类型是%T, b_str=%s\n", b_bool, b_str, b_str) // 法2: bool转string
b1_bool := false
b1_str := strconv.FormatBool(b1_bool)
fmt.Printf("b1_bool的数据类型是%T, b1_str的数据类型是%T, b1_str=%s\n", b1_bool, b1_str, b1_str)
输出结果为:
b_bool的数据类型是bool, b_str的数据类型是string, b_str=true
b1_bool的数据类型是bool, b1_str的数据类型是string, b1_str=false
4. char 转 string
这个有点特殊,打印出来的数据类型不是char型
c_char := '@'
c_str := fmt.Sprintf("%c", c_char)
fmt.Printf("c_char的数据类型是%T, c_str的数据类型是%T, c_str=%s\n", c_char, c_str, c_str)
输出结果为:
c_char的数据类型是int32, c_str的数据类型是string, c_str=@
还需进一步研究。
源代码:
package main import (
"fmt"
"strconv"
) func main() { // 法1: int转string
num_int := 10
num_str_2 := fmt.Sprintf("%b", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_2的数据类型是%T, num_str_2=%s\n", num_int, num_str_2, num_str_2)
num_str_8 := fmt.Sprintf("%o", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_8的数据类型是%T, num_str_8=%s\n", num_int, num_str_8, num_str_8)
num_str_10 := fmt.Sprintf("%d", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_10的数据类型是%T, num_str_10=%s\n", num_int, num_str_10, num_str_10)
num_str_16 := fmt.Sprintf("%0x", num_int)
fmt.Printf("num_int的数据类型是%T, num_str_16的数据类型是%T, num_str_16=%s\n", num_int, num_str_16, num_str_16) // 法2: int转string
num1_int := 128
num1_str_2 := strconv.FormatInt(int64(num1_int), 2)
num1_str_8 := strconv.FormatInt(int64(num1_int), 8)
num1_str_10 := strconv.Itoa(num1_int)
num1_str_16 := strconv.FormatInt(int64(num1_int), 16)
fmt.Printf("num1_int的数据类型是%T, num1_str_2的数据类型是%T, num1_str_2=%s\n", num1_int, num1_str_2, num1_str_2)
fmt.Printf("num1_int的数据类型是%T, num1_str_8的数据类型是%T, num1_str_8=%s\n", num1_int, num1_str_8, num1_str_8)
fmt.Printf("num1_int的数据类型是%T, num1_str_10的数据类型是%T, num1_str_10=%s\n", num1_int, num1_str_10, num1_str_10)
fmt.Printf("num1_int的数据类型是%T, num1_str_16的数据类型是%T, num1_str_16=%s\n", num1_int, num1_str_16, num1_str_16) // 法1: float转string
num_float := 12.75
num_str := fmt.Sprintf("%f", num_float)
fmt.Printf("num_float的数据类型是%T,num_str的数据类型是%T,num_str=%s\n", num_float, num_str, num_str)
num_str_k3 := fmt.Sprintf("%.3f", num_float)
fmt.Printf("num_float的数据类型是%T,num_str_k3的数据类型是%T,num_str_k3=%s\n", num_float, num_str_k3, num_str_k3)
num_str_k1 := fmt.Sprintf("%.1f", num_float)
fmt.Printf("num_float的数据类型是%T,num_str_k1的数据类型是%T,num_str_k1=%s\n", num_float, num_str_k1, num_str_k1) // 法2: float转string
num1_float := 128.99000003253
num1_str_k8 := strconv.FormatFloat(num1_float, 'f', 8, 64)
fmt.Printf("num1_float的数据类型是%T, num1_str_k8的数据类型是%T, num1_str_k8=%s\n", num1_float, num1_str_k8, num1_str_k8)
num1_str_k2 := strconv.FormatFloat(num1_float, 'f', 2, 64)
fmt.Printf("num1_float的数据类型是%T, num1_str_k2的数据类型是%T, num1_str_k2=%s\n", num1_float, num1_str_k2, num1_str_k2)
num1_str_k0 := strconv.FormatFloat(num1_float, 'f', 0, 64)
fmt.Printf("num1_float的数据类型是%T, num1_str_k0的数据类型是%T, num1_str_k0=%s\n", num1_float, num1_str_k0, num1_str_k0) // 法1: bool转string
b_bool := true
b_str := fmt.Sprintf("%t", b_bool)
fmt.Printf("b_bool的数据类型是%T, b_str的数据类型是%T, b_str=%s\n", b_bool, b_str, b_str) // 法2: bool转string
b1_bool := false
b1_str := strconv.FormatBool(b1_bool)
fmt.Printf("b1_bool的数据类型是%T, b1_str的数据类型是%T, b1_str=%s\n", b1_bool, b1_str, b1_str) c_char := '@'
c_str := fmt.Sprintf("%c", c_char)
fmt.Printf("c_char的数据类型是%T, c_str的数据类型是%T, c_str=%s\n", c_char, c_str, c_str) }
OK。
第三篇 -- Go语言其他类型转String方法的更多相关文章
- 15天玩转redis —— 第三篇 无敌的列表类型
据说60%的人使用redis看重的是redis中的list类型,那这个list有什么用呢???不用我说大家都明白,做队列使用呗,为什么用它呢,很简单呗, 因为有了它我就不需要专门的MQ产品啦,比如说 ...
- 第三篇T语言实例开发,图色操作
---恢复内容开始--- 图色的基本操作 1.找颜色色命令的基本操作 坐标点取色:获取指定坐标点的颜色 区域找色:在指定区域里找某一个颜色 模糊找色:在指定区域里找某一个颜色,可以设置相似度 多点找色 ...
- 第三篇T语言热键启动方法
热键控件 热键控件的使用方法 第一步:选择热键添加到面板上. 第二步:热键控件属性选择热键键值. 第三步:添加热键事件功能. 热键模式的选择 1.普通模式 2.软件模式 3.硬件模式 脚本的基本操作 ...
- 深入理解javascript选择器API系列第三篇——h5新增的3种selector方法
× 目录 [1]方法 [2]非实时 [3]缺陷 前面的话 尽管DOM作为API已经非常完善了,但是为了实现更多的功能,DOM仍然进行了扩展,其中一个重要的扩展就是对选择器API的扩展.人们对jQuer ...
- 深入理解javascript选择器API系列第三篇——HTML5新增的3种selector方法
前面的话 尽管DOM作为API已经非常完善了,但是为了实现更多的功能,DOM仍然进行了扩展,其中一个重要的扩展就是对选择器API的扩展.人们对jQuery的称赞,很多是由于jQuery方便的元素选择器 ...
- 深入理解Java 8 Lambda(语言篇——lambda,方法引用,目标类型和默认方法)
作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-language- ...
- [转]深入理解Java 8 Lambda(语言篇——lambda,方法引用,目标类型和默认方法)
以下内容转自: 作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-l ...
- Scala语言笔记 - 第三篇(容器方法篇)
Scala语言笔记 - 第三篇(容器方法篇) 目录 Scala语言笔记 - 第三篇(容器方法篇) map和flapMap方法: 最近研究了下scala语言,这个语言最强大的就是它强大的函数式编程( ...
- Lambda语言篇 —— lambda, 方法引用, 目标类型和默认方法
本文介绍了Java SE 8中新引入的lambda语言特性以及这些特性背后的设计思想.这些特性包括: lambda表达式(又被成为"闭包"或"匿名方法") 方法 ...
随机推荐
- fiddler操作详情
1.设置fiddler请求过滤 2.请求与响应的格式内容 3.拦截请求操作 a.按F11开始拦截,发送请求 b.修改请求数据 c.SHIFT+F11关闭拦截 d.run to complete,把修 ...
- Mysql优化(出自官方文档) - 第十二篇(优化锁操作篇)
Mysql优化(出自官方文档) - 第十二篇(优化锁操作篇) 目录 Mysql优化(出自官方文档) - 第十二篇(优化锁操作篇) 1 Internal Locking Methods Row-Leve ...
- Netty 框架学习 —— 编解码器框架
编解码器 每个网络应用程序都必须定义如何解析在两个节点之间来回传输的原始字节,以及如何将其和目标应用程序的数据格式做相互转换.这种转换逻辑由编解码器处理,编解码器由编码器和解码器组成,它们每种都可以将 ...
- 冷饭新炒 | 深入Quartz核心运行机制
目录 Quartz的核心组件 JobDetail Trigger 为什么JobDetail和Trigger是一对多的关系 常见的Tigger类型 怎么排除掉一些日期不触发 Scheduler List ...
- js笔记14
1.作用域面试题 画图分析 2.DOM document object model 节点树状图 document>documentElement>body>tagname 3.我们常 ...
- 源码搭建Zabbix4.0.23LTS监控系统
实验环境 centos 7.5 主机名 IP地址 配置 应用 controlnode 172.16.1.120/24 4核/8G/60G java-1.8.0-openjdk zabbix serve ...
- ps 快速去掉不需要的部分
1.打开图片---使用套索工具将不需要的圈起来----右键填充--直接点击确定就可以了
- Jenkins之搭建部署
一.部署环境 操作系统:Centos7 软件: apache-tomcat-9.0.48--地址:https://tomcat.apache.org/download-90.cgi jdk-8u291 ...
- Java:Java中equlas和==的区别
== 比较的是栈内存的地址值,用来判断两个对象的地址是否相同,即是否是指相同一个对象.比较的是真正意义上的指针操作. 基本数据类型如:byte,short,char,int,long,float,do ...
- konga的初步使用
目录 1. 设置连接 2. konga的重要功能 Dashboard Snapshots Settings 3. 通过konga 实现kong api配置 前言: 在上篇文章中,我们已经创建了一个到k ...