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方法的更多相关文章

  1. 15天玩转redis —— 第三篇 无敌的列表类型

     据说60%的人使用redis看重的是redis中的list类型,那这个list有什么用呢???不用我说大家都明白,做队列使用呗,为什么用它呢,很简单呗, 因为有了它我就不需要专门的MQ产品啦,比如说 ...

  2. 第三篇T语言实例开发,图色操作

    ---恢复内容开始--- 图色的基本操作 1.找颜色色命令的基本操作 坐标点取色:获取指定坐标点的颜色 区域找色:在指定区域里找某一个颜色 模糊找色:在指定区域里找某一个颜色,可以设置相似度 多点找色 ...

  3. 第三篇T语言热键启动方法

    热键控件 热键控件的使用方法 第一步:选择热键添加到面板上. 第二步:热键控件属性选择热键键值. 第三步:添加热键事件功能. 热键模式的选择 1.普通模式 2.软件模式 3.硬件模式 脚本的基本操作 ...

  4. 深入理解javascript选择器API系列第三篇——h5新增的3种selector方法

    × 目录 [1]方法 [2]非实时 [3]缺陷 前面的话 尽管DOM作为API已经非常完善了,但是为了实现更多的功能,DOM仍然进行了扩展,其中一个重要的扩展就是对选择器API的扩展.人们对jQuer ...

  5. 深入理解javascript选择器API系列第三篇——HTML5新增的3种selector方法

    前面的话 尽管DOM作为API已经非常完善了,但是为了实现更多的功能,DOM仍然进行了扩展,其中一个重要的扩展就是对选择器API的扩展.人们对jQuery的称赞,很多是由于jQuery方便的元素选择器 ...

  6. 深入理解Java 8 Lambda(语言篇——lambda,方法引用,目标类型和默认方法)

    作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-language- ...

  7. [转]深入理解Java 8 Lambda(语言篇——lambda,方法引用,目标类型和默认方法)

    以下内容转自: 作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-l ...

  8. Scala语言笔记 - 第三篇(容器方法篇)

    Scala语言笔记 - 第三篇(容器方法篇) 目录 Scala语言笔记 - 第三篇(容器方法篇) map和flapMap方法: ​ 最近研究了下scala语言,这个语言最强大的就是它强大的函数式编程( ...

  9. Lambda语言篇 —— lambda, 方法引用, 目标类型和默认方法

    本文介绍了Java SE 8中新引入的lambda语言特性以及这些特性背后的设计思想.这些特性包括: lambda表达式(又被成为"闭包"或"匿名方法") 方法 ...

随机推荐

  1. UF_OBJ 对象操作

    Open C uc5027uc5028uc5029uc502auc502euc502muc502nuc502ruc5203uf5025uf5026UF_OBJ_ask_cre_mod_versions ...

  2. 图文并茂教你学会使用 IntelliJ IDEA 进行远程调试

    1. 前言 今天线上出现了个 Bug ,而且比较坑的是涉及到微信相关的东西不能线下调试.传统方式是在代码中各种的日志 log 埋点然后重新部署进行调试,再根据 log 中的信息进行分析.如果你的 lo ...

  3. 【数论】8.30题解-prime素数密度 洛谷p1835

    prime 洛谷p1835 题目描述 给定区间[L, R](L <= R <= 2147483647, R-L <= 1000000),请计算区间中 素数的个数. 输入输出 输入 两 ...

  4. 大数据初级sy

    1.spark 是用以下哪种编程语言实现的? A.C             B  C++       C   JAVA               D.Scala (正确答案) 2.FusionIn ...

  5. cisco交换机端口从errdisable状态恢复

    故障描述 经用户反馈,一台cisco2960x接入交换机的一个端口插网线不通,ip电话也没有poe供电. 排查过程 查看交换机端口状态,发现变成了errdisable: ZH_HQN_SW2960X_ ...

  6. 可编程网络DataPath 及XDP

    目录 可编程网络DataPath XDP 的基本架构 XDP 的软件要求 XDP 的硬件要求 XDP 的工作流程及使用 XDP 的工作模式 XDP 的工作流程 Hello World XDP 的应用 ...

  7. redis学习第二天

    Redis 在 2.8.9 版本之后添加了 HyperLogLog 结构 Redis HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常 ...

  8. 『心善渊』Selenium3.0基础 — 10、使用Seleniun定位页面元素归纳总结(超详细)

    目录 1.Selenium中8种基本元素定位方式 (1)单数形式 (2)复数形式 2.By类定位的8种定位方式 (1)单数形式 (2)复数形式 3.XPath定位总结 (1)基础定位语法 (2)属性定 ...

  9. Xmanager6 企业版安装

    Xmanager6 企业版安装 链接:https://pan.baidu.com/s/1QZOD0iPd4WbVHBVXIbJ-fw 提取码:ebkl 一.安装教程 1.1 下载解压,双击安装exe主 ...

  10. vue 快速入门 系列 —— vue loader 上

    其他章节请看: vue 快速入门 系列 vue loader 上 通过前面"webpack 系列"的学习,我们知道如何用 webpack 实现一个不成熟的脚手架,比如提供开发环境和 ...