03【保姆级】-GO语言变量和数据类型和相互转换

03【保姆级】-GO语言变量和数据类型

  • 一、变量
    • 1.1 变量的定义:
    • 1.2 变量的声明、初始化、赋值
    • 1.3 变量使用的注意事项
  • 插播-关于fmt.Printf格式打印%的作用
  • 二、 变量的数据类型
    • 2.1整数的基本类型
      • 2.1.1 有符号类型 int8/16/32/64
      • 2.1.2 无符号类型 int8/16/32/64
      • 2.1.3 整型类型 int、uint、rune、byte
      • 2.1.4 整型的使用细节
    • 2.2 浮点类型
      • 2.2.1 小数类型分类
    • 2.3 字符类型
      • 2.3.1 基本介绍
      • 2.3.2 字符使用细节
    • 2.4 布尔类型
      • 2.4.1 基本概述
    • 2.5 String类型
      • 2.5.1 基本概述
      • 2.5.2 String使用注意事项和细节
    • 2.6 基本数据类型的默认值
    • 2.7 基本数据类型的相互转换
    • 2.8 转换的细节(重要)
    • 2.9 基本数据类型转String(重要)
      • 2.9.1 fmt.Sprintf("%参数", 变量名)
      • 2.9.2 使用strconv包的函数
    • 2.10 String类型转为基本类型
      • 2.10.1 使用strconv包的函数

之前我学过C、Java、Python语言时总结的经验:

  1. 先建立整体框架,然后再去抠细节。
  2. 先Know how,然后know why。
  3. 先做出来,然后再去一点点研究,才会事半功倍。
  4. 适当的囫囵吞枣。因为死抠某个知识点很浪费时间的。
  5. 对于GO语言,切记遵守语法格式规则。(例如python语言、例如SpringBoot框架等)
    解释:某些知识点,就是很难了解,那么先做出来,然后继续向前学习,可能在某个时间点我们就会恍然大悟。

一、变量

1.1 变量的定义:

  • 任何高级程序语言写程序,变量都是程序的基本组成单位。
  • 变量相当于内存中一个数据存储空间的表示,你可以把变量看做是一个房间的门牌号,通过门牌号我们可以找到房间,同样的道理,通过变量名可以访问到变量()

1.2 变量的声明、初始化、赋值

  1. 声明变量(定义变量)

基本语法: var 变量名 数据类型
var a int

  1. 变量赋值

在声明变量的时候,就给值
var a int = 1
var b = 300

  1. 使用变量

var a int
a = 100

例如下面的a/b/c都是变量


package main

import "fmt"

func main() {
	var a int  //声明变量
	a = 10     //变量赋值
	b := 20    //变量赋值
	c := a + b //使用变量
	fmt.Println(a) // 10
	fmt.Println(b) // 20
	fmt.Println(c) // 30
}

1.3 变量使用的注意事项

  1. 变量表示内存中的一个存储区域
  2. 该区域有自己的名称(变量名)和类型(数据类型)

所有代码会用磁盘中读取到内存中,进行运行。
那么变量,例如a = 10 。那么就会存储到内存中。

  1. Golang变量使用的三种方式

    1. 第一种:指定变量类型,声明后若不赋值,使用默认值。

    int类型默认为0
    String类型默认为空

    1. 第二种:根据值自行判定变量类型(类型推导)

    如果不指定类型,那么就会go语言类型推导。
    var a = “abc” 在打印的时候就会输出string类型

    1. 第三种省略var,注意:=左侧的变量不应该是已经声明过的,否则会导致编译错误

    两种方式:(方式一的两句话,等价于方式二)
    > var name1 string
    name1 = “zhangsan1” //方式一
    name2 := “zhangsan2” //方式二

  2. 多变量声明
    在编程中,有时我们需要一次性声明多个变量,Golang也提供这样的语法

形式一:
var a, a1, a2, a3 int
a = 10
a1 = 20
a2 = 30
a3 = 40


形式二:
var a1, a2, a3, name = 1, 2, 3, "zhangsan"
	fmt.Println(a1,a12,a23,a4)

形式三:
a, b, c, d, name := 1, 2, 3, 4, "zhangsan"
fmt.Println(a,b,c,d,name)

关于全局变量:

var (
	a    = 1
	b    = 2
	c    = 3
	d    = 4
	name = "zhangsan"
)
func main() {
	fmt.Println(a, b, c, d, name)
}
  1. 该区域的数据值可以在同一类型范围内不断变化
  2. 变量在同一个作用域内不能重名
  3. 变量=变量名+值+数据类型,这一点请大家注意。
  4. Golang的变量如果没有赋初值,编译器会使用默认值,比如int默认值0 string默认值为空用

插播-关于fmt.Printf格式打印%的作用

参考的官网地址是:https://studygolang.com/pkgdoc

通用:
%v	值的默认格式表示
%+v	类似%v,但输出结构体时会添加字段名
%#v	值的Go语法表示
%T	值的类型的Go语法表示
%%	百分号

布尔值:
%t	单词truefalse

整数:

%b	表示为二进制
%c	该值对应的unicode码值
%d	表示为十进制
%o	表示为八进制
%q	该值对应的单引号括起来的go语法字符字面值,必要时会采用安全的转义表示
%x	表示为十六进制,使用a-f
%X	表示为十六进制,使用A-F
%U	表示为Unicode格式:U+1234,等价于"U+%04X"

浮点数与复数的两个组分:

%b	无小数部分、二进制指数的科学计数法,如-123456p-78;参见strconv.FormatFloat
%e	科学计数法,如-1234.456e+78
%E	科学计数法,如-1234.456E+78
%f	有小数部分但无指数部分,如123.456
%F	等价于%f
%g	根据实际情况采用%e或%f格式(以获得更简洁、准确的输出)
%G	根据实际情况采用%E或%F格式(以获得更简洁、准确的输出)

字符串和[]byte%s	直接输出字符串或者[]byte
%q	该值对应的双引号括起来的go语法字符串字面值,必要时会采用安全的转义表示
%x	每个字节用两字符十六进制数表示(使用a-f)
%X	每个字节用两字符十六进制数表示(使用A-F)    

指针:

%p	表示为十六进制,并加上前导的0x    

二、 变量的数据类型

在这里插入图片描述

2.1整数的基本类型

简单的说,就是用于存放整数值的,比如 0,-1,2345 等等。

2.1.1 有符号类型 int8/16/32/64

在这里插入图片描述

** int8 范围是:-128 ~ 127**
在这里插入图片描述

2.1.2 无符号类型 int8/16/32/64

int 无符号类型:
在这里插入图片描述

2.1.3 整型类型 int、uint、rune、byte

在这里插入图片描述

2.1.4 整型的使用细节

  1. Golang 各整数类型分: 有符号和无符号,int uint 的大小和系统有关
  2. Golang 的整型默认声明为 int 型
  3. 如何在程序查看某个变量的字节大小和数据类型
import (
	"fmt"
	unsafe "unsafe"
)

	var n1 = 100
	fmt.Printf("n1 的类型是 %T ", n1) //n1 的类型是 int

	var n2 int64 = 1
	fmt.Printf("n1 的数据类型是 %T, n2 占用的字节数是%d", n2, unsafe.Sizeof(n2))
	//   n1 的数据类型是 int64, n2 占用的字节数是8
  1. olang 程序中整型变量在使用时,遵守保小不保大的原则,即:在保证程序正确运行下,尽量使用占用空间小的数据类型。[如: 年龄]
  2. bit: 计算机中的最小存储单位。byte:计算机中基本存储单元。[二进制再详细说] 1byte = 8 bit

2.2 浮点类型

Golang的浮点类型可以表示一个小数,比如1.2 / 3333.11 / 3232.324等等

2.2.1 小数类型分类

在这里插入图片描述

  1. 关于浮点数在机器中存放形式的简单说明.浮点数=符号位+指数位+尾数位说明: 浮点数都是有符号的.
  2. 如果使用float32 可能造成精度损失。

开发过程中,推荐使用float64。 并且默认也是float64 .
Golang浮点类型有固定的范围和字段类型,不受具体操作系统的影响。
在这里插入图片描述

  1. 浮点型的存储分为三个部分:符号位+指数位+尾数位。 在存储过程中,精度会有丢失

2.3 字符类型

2.3.1 基本介绍

Golang 中没有专门的字符类型,如果要存储单个字符(字母),一般使用 byte 来保存。
字符串就是一串固定长度的字符连接起来的字符序列。Go 的字符串是由单个字节连接起来的。也就是说对于传统的字符串是由字符组成的,而 Go 的字符串不同,它是由字节组成的。

  1. 如果我们保存的字符在 ASCII 表的,比如[0-1,a-z,A-Z.]直接可以保存到 byte2)
  2. 如果我们保存的字符对应码值大于 255,这时我们可以考虑使用 int 类型保存3)
  3. 如果我们需要安装字符的方式输出,这时我们需要格式化输出,即 fmt.Printfr“%c”,cl)…
var n2 int = '你'
	fmt.Printf("n2 的数据类型是 %T, n2 占用的字节数是%d.  \n", n2, unsafe.Sizeof(n2))
	// n2 的数据类型是 int, n2 占用的字节数是8. 

	var c3 int = '你'
	fmt.Printf("c3 = %c \n", c3)	//c3 = 你	
	fmt.Printf("%c", c3) 			//你

2.3.2 字符使用细节

在这里插入图片描述

  1. 字符型 存储到 计算机中,需要将字符对应的码值 (整数) 找出来存储:字符—>对应码值---->二进制–>存储
    读取:二进制----> 码值 ----> 字符 -> 读取
  2. 字符和码值的对应关系是通过字符编码表决定的(是规定好)
  3. Go 语言的编码都统一成了 utf-8。非常的方便,很统一,再也没有编码乱码的困扰了

2.4 布尔类型

2.4.1 基本概述

  1. 布尔类型也叫 bool类型,bool 类型数据只允许取值 true 和 false
  2. bool类型占1 个字节。
  3. bool 类型适于逻辑运算,一般用于程序流程控制
	seg := true
	fmt.Printf("%T  \n", seg) //bool
	fmt.Println("seg=", seg)    //seg= true

if seg {
		fmt.Println("如果是true, 我就打印")
	} else {
		fmt.Println("如果是false, 我就打印")
	}

2.5 String类型

2.5.1 基本概述

字符串就是一串固定长度的字符连接起来的字符序列。Go 的字符串是由单个字节连接起来的。Go语言的字符串的字节使用 UTF-8 编码标识 Unicode 文本。

var name string = "今年张三,英文ZhangSan,23岁了。"
	fmt.Println(name)

2.5.2 String使用注意事项和细节

  1. Go语言的字符串的字节使用UTF-8编码标识Unicode文本,这样Golang统一使用Utf-8编码,中文乱码就不会出现了。
  2. 字符串一旦赋值后,字符串就不能单个字符修改了。在Go中字符串是不可变的。
var str = "hello"
str[0] = 'b'  //这里就会报错了。字符串单个字符是不可变的。

可以直接从新赋值:
str ="word"

在这里插入图片描述
3. 字符串的两种表示方式
1. 双引号,会识别转义字符
2. 反引号,以字符串的原生形式输出,包括换行和特殊字符,可以实现防止攻击、输出源代码等效果。
在这里插入图片描述
4. 字符串拼接方式

	str := "hello "
	name := "zhangsan"
	strName := str + name
	fmt.Println(strName)  //hello zhangsan
  1. 当一行字符串太长时,需要使用多行字符串,可以用“” + 进行绑定。 重点是:+ 号必须保持在上一行中。
str := "lisi " + "wangwu " + " zhaoliu " + " a" +
	" b" + "c " +
	"D"

fmt.Println(str)  //lisi wangwu  zhaoliu  a bc D

2.6 基本数据类型的默认值

在Go中,数据类型都有一个默认值,当没有赋值时,就会保留默认值,在Go中,默认值又叫“零值”
在这里插入图片描述

2.7 基本数据类型的相互转换

Golang和java、C不同,在Go语言中,不同类型的变量之间赋值时需要显式转换。 也就是说Golang中数据类型不能自动转换

基本语法:

  • 表达式T(v) 将值 v 转换为类型T
    • T:就是数据类型,比如:int32 , int64 ,float32, float64等
    • V:就是需要转换的变量
var n1 int = 100
var n2 float64 = float64(n1)
n2 += 0.905
var n3 int = int(n2)
fmt.Printf("n1=%v, n2=%v, n3=%v", n1, n2, n3)
// n1=100, n2=100.905, n3=100

2.8 转换的细节(重要)

  1. 在Go中,数据类型的转换可以是从 小范围 转换到 大范围。也可以从 大范围 转换成 小范围。
  2. 被转换的是变量存储的数据(既值) ,变量本身的数据类型并没有变化。

例如:
我们将 n1 float =1.23 转换成 n2 int = 100
那么分别打印 n1 =1.23. 打印n2 =100
var n1 float64 = 1.23
var n2 int = int(n1)
fmt.Printf(“n1=%v, n2=%v”, n1, n2)
// 打印结果:n1=1.23, n2=1

  1. 在转换结果中,比如将Int64转换成int8 ,编译时不会报错 ,只是转换的结果是按溢出处理,和我们希望的结果不一样。
var n1 int64 = 999999
var n2 int8 = int8(n1)
fmt.Printf("n1=%v, n2=%v", n1, n2)
//  n1=999999, n2=63

2.9 基本数据类型转String(重要)

在程序开发中,我们经常需要将基本数据类型转成String类型。
或者String类型转换成基本数据类型。

2.9.1 fmt.Sprintf(“%参数”, 变量名)

方式一: fmt.Sprintf(“%参数", 表达式)

  1. 参数需要和表达式的数据类型相匹配
  2. fmt.Sprintf() 会返回转换后的字符串
package main

import "fmt"

func main() {
	var n1 int = 123
	var n2 float64 = 1.23
	var n3 byte = 'a'
	var n4 bool = true
	var str string

	// %T 的意思是:该变量的类型
	// %q 的意思是:打印变量的类型,并且用双引号,引起来。
	str = fmt.Sprintf("%d", n1)
	fmt.Printf("str的类型是:%T, Str等于%q\n", str, str)

	str = fmt.Sprintf("%f", n2)
	fmt.Printf("str的类型是%T,str等于:%q \n", str, str)

	str = fmt.Sprintf("%c", n3)
	fmt.Printf("str的类型是:%T,str等于%q \n", str, str)
	str = fmt.Sprintf("%t", n4)
	fmt.Printf("str的类型是%T,str等于%q \n", str, str)
}
str的类型是string, Str等于"123"
str的类型是string, str等于:"1.230000" 
str的类型是:string str等于"a" 
str的类型是string, str等于"true" 

2.9.2 使用strconv包的函数

方式二:使用strconv包的函数
3. func FomatBool(b lool) String
4. func FomatInt(i int64, base int ) String

	var num1 int = 123
	var num2 float64 = 1.234
	var num3 bool = true
	var str string

	fmt.Printf("num1的类型是:%T \n", num1)
	str = strconv.FormatInt(int64(num1), 10)
	fmt.Printf("str的类型是:%T,str的值是:%q \n", str, str)

	//要转换的变量,
	//'f':格式是:ddd.dddd。 一般使用的比较多
	//精度(小数点后面几位),该float的位数,例如64/32
	str = strconv.FormatFloat(num2, 'f', 2, 64)
	fmt.Printf("str的类型是:%T,str的值是%q \n", str, str)

	str = strconv.FormatBool(num3)
	fmt.Sprintf("str的类型是:%T,str的值是%q", str, str)

num1的类型是:int 
str的类型是:string,str的值是:"123" 
str的类型是:string,str的值是"1.23" 

 
Itoa 将int类型转为String类型:
var num1 int = 100
	var str string = strconv.Itoa(num1)
	fmt.Printf(str)

关于strconv.FormatFloat的参数说明:
在这里插入图片描述

2.10 String类型转为基本类型

2.10.1 使用strconv包的函数

func ParseBool
func ParseBool(str string) (value bool, err error)
返回字符串表示的bool值。它接受1、0、t、f、T、F、true、false、True、False、TRUE、FALSE;否则返回错误。

	var str string = "true"
	var err error
	var b bool
	b, err = strconv.ParseBool(str)
	fmt.Printf("b的类型是 %T,b的值是%v,b的错误结果是:%v \n", b, b, err)

func 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。

	var str string = "123"
	var i int64
	// 要转的字符串,base:转成10进制,bitSize:转成64位
	i, _ = strconv.ParseInt(str, 10, 0)
	fmt.Printf("i的格式是:%T,  i的值是:%v", i, i)
	// i的格式是:int64,  i的值是:123
  • func 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。

	var str string = "1.2345"
	var f float64
	f, _ = strconv.ParseFloat(str, 64)
	fmt.Printf("f的类型是%T, f的值是:%v", f, f)
	// f的类型是float64, f的值是:1.2345

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/119385.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

云安全—Dashboard 攻击面

0x00 前言 众所周知,如果只是一味的REST接口或者命令行话的操作方式,就会变相的提高操作门款,并且不会有很好的呈现方式,所以就有了web ui的方式,也就是Dashboar面板,本篇主要讨论一下关于Dashboar面板的概…

第八章认识Express框架

目录 Express模块化路由 基本概述 基本使用 基本构建 案例项目 Express接收请求参数 基本概述 基本类别 Express接收GET请求参数 Express接收POST请求参数 Express接收路由参数 Express模块化路由 基本概述 在Express中,路由是指确定应用程序如何响应对…

Python语言高级实战-内置函数super()的使用之类的单继承(附源码和实现效果)

实现功能 super()是一个内置函数,用于调用父类的方法。super() 是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO)、重复调用&#xf…

Android Studio(项目收获)

取消按钮默认背景色 像按钮默认背景色为深蓝色&#xff0c;即使使用了background属性指定颜色也不能生效。 参考如下的解决方法&#xff1a; 修改/res/values/themes.xml中的指定内容如下&#xff1a; <style name"Theme.TianziBarbecue" parent"Theme.Mater…

服务号怎么改成订阅号

服务号和订阅号有什么区别&#xff1f;服务号转为订阅号有哪些作用&#xff1f;在推送频率上来看&#xff0c;服务号每月能推送四条消息&#xff0c;而订阅号可以每天&#xff08;24小时&#xff09;推送一条消息。如果企业开通公众号的目的是提供服务&#xff0c;例如售前资讯…

二叉树—相关计算题

目录 一、概念题 二、计算题 1、节点数 2、深度 3、遍历序列 一、概念题 1、在用树表示的目录结构中&#xff0c;从根目录到任何数据文件&#xff0c;有&#xff08; &#xff09;通道 答案&#xff1a;唯一一条&#xff0c;树的特点是不相交&#xff0c;所以不可能有多…

uniapp打包嵌入app,输入框被键盘遮挡的问题

问题描述&#xff1a;将uniapp开发的应用打包成wgt包放入app后&#xff0c;发现安卓手机的输入框会被手机输入法的键盘遮挡&#xff0c;导致看不到自己输入了什么内容&#xff1b;而在ios端是正常的&#xff0c;输入框会被键盘顶起&#xff0c;能清楚看到自己输入的内容。 在解…

数据库实验:SQL的数据视图

目录 视图概述视图的概念视图的作用 实验目的实验内容实验要求实验过程 视图概述 视图是由数据库中的一个表或多个表导出的虚拟表&#xff0c;其作用是方便用户对数据的操作 视图的概念 视图是一个虚拟表&#xff0c;其内容由查询定义。同真实的表一样&#xff0c;视图包含一…

升级 MacOS 系统后,playCover 内游戏打不开了如何解决

我们有些小伙伴在升级了 macOS 系统后大概率会遇到之前能够正常使用的 playCover 突然游戏打不开了&#xff0c;最近 mac 刚刚正式推出了 MacOS 14.1 ,导致很多用户打开游戏会闪退&#xff0c;我们其实只需要更新一下 playCover 就可以解决 playCover 正式版更新会比较慢所以我…

北京陪诊小程序|陪诊系统开发|陪诊小程序未来发展不可小觑

近几年随着互联网快速发展&#xff0c;各行业领域都比较注重线上服务系统&#xff0c;通过陪诊小程序开发可以满足更多用户使用需求&#xff0c;同时还能提高用户使用体验。现在陪诊类的软件应用得到全面推广&#xff0c;在医疗行业当中陪诊小程序更贴近用户生活&#xff0c;可…

CN考研真题知识点二轮归纳(4)

持续更新&#xff0c;上期目录&#xff1a; CN考研真题知识点二轮归纳&#xff08;4&#xff09;https://blog.csdn.net/jsl123x/article/details/134135134?spm1001.2014.3001.5501 1.既可以扩展网段又是二层的设备 网段一般指一个计算机网络中使用同一物理层设备&#xff…

el-select多选以tag展示时,超过显示长度以...省略号显示,且在一行展示

效果&#xff1a; 代码&#xff1a; <span>系统词典维度&#xff1a;</span><el-selectv-model"dNum"placeholder"请选择"multiplecollapse-tags //设置collapse-tags属性将它们合并为一段文字size"small"style"width:160p…

LabVIEW示波器连续触发编程

LabVIEW示波器连续触发编程 niScopeEX Fetch Forever范例利用了如何设置硬件和驱动的优点来进行连续采集。 当NI-SCOPE设备被设置为采集预触发扫描&#xff0c;设备上的板载内存被用作一个环形缓冲。这样&#xff0c;无论触发何时到来&#xff0c;设备都可以追踪和检索所有要求…

vs code 和 hbuilder 历史记录查询

一.Hbuilder 找到需要的文件右键 二. vs code

Linux操作系统中软件安装:用RPM包管理器安装软件步骤

安装软件的一般步骤如下&#xff1a; 1.打开终端&#xff0c;作为root用户或使用sudo命令获取管理员权限。 2.使用RPM命令进行软件包的安装。例如&#xff0c;使用“rpm -ivh 软件包名称.rpm”命令来安装软件包&#xff0c;其中“-i”表示安装&#xff0c;“-v”表示显示详细安…

centos7.9 postgresql 16.0 源码安装部署

postgresql 16.0 源码安装部署 环境准备 系统主机名IP地址centos7.9postgres192.168.200.56 软件准备 postgresql-16.0.tar.gz https://ftp.postgresql.org/pub/source/v16.0/postgresql-16.0.tar.gz依赖安装 yum -y install systemd-devel readline readline-devel zlib-devel…

数据可视化:动态柱状图

终于来到最后一个数据可视化的文章拿啦~~~ 在这里学习如何绘制动态柱状图 我先整个活 (๑′ᴗ‵๑)&#xff29; Lᵒᵛᵉᵧₒᵤ❤ 什么是pyecharts&#xff1f; 答&#xff1a; Python的Pyecharts软件包。它是一个用于Python数据可视化和图表绘制的库&#xff0c;可用于制作…

openGauss学习笔记-116 openGauss 数据库管理-设置数据库审计-审计概述

文章目录 openGauss学习笔记-116 openGauss 数据库管理-设置数据库审计-审计概述116.1 背景信息116.2 操作步骤 openGauss学习笔记-116 openGauss 数据库管理-设置数据库审计-审计概述 116.1 背景信息 数据库安全对数据库系统来说至关重要。openGauss将用户对数据库的所有操作…

一个高性能类型安全的.NET枚举实用开源库

从零构建.Net前后端分离项目 枚举应该是我们编程中&#xff0c;必不可少的了&#xff0c;今天推荐一个.NET枚举实用开源库&#xff0c;它提供许多方便的扩展方法&#xff0c;方便开发者使用开发。 01 项目简介 Enums.NET是一个.NET枚举实用程序库&#xff0c;专注于为枚举提…

Python如何解析json对象?

目录 一、JSON简介 二、Python的json模块 1. 加载JSON数据 2. 生成JSON数据 三、处理复杂的JSON数据 四、自定义JSON解析器 五、注意事项和最佳实践 六、总结 JSON&#xff08;JavaScript Object Notation&#xff09;作为一种轻量级的数据交换格式&#xff0c;在网络通…