写给.NET开发者的Python教程(二):基本类型和变量
从本文开始,我们就要正式了解Python的语法特性了,这章主要介绍基本类型和变量,开始之前先介绍下Python中的标准输入输出。
标准输入输出
前文举过TwoSum问题的例子,但是没有讲到标准输入输出的处理,因为那部分leetcode平台帮我们处理了。但实际上标准输入输出是非常重要的,是我们编写任何代码都必须先了解的语法,这里以C#做对比,介绍Python的标注输入方法input和标准输出方法print。
input方法在Python中的作用和Console.ReadLine一致,可以从电脑获得用户的输入数据,称之为标准输入。在Python 2中标注输入分为input和raw_input两个方法,其中input只能接受明确格式的输入,要么输入字符串要么数字,混合在一起会报错。这一点在Python 3中得到了改进,统一合并为input方法。因此从功能上,input和C#的标准输入功能一致,都允许用户输入任何内容,并以字符串的形式读取。
print方法作为Python的标准输出方法,可以将任何对象输出为字符串。但这里值得注意的是,Python并不支持字符串和不同值类型的直接相加,这会导致异常抛出。而C#支持此特性,如下:
因此在Python中需要将其他类型先转换为字符串才可以直接字符串变量相加,如下:
基本类型
基本类型是数据操作的起步,前面的内容已经出现过字符串和数值之类的操作。Python的基本类型主要分为整形(int),浮点数(float),复数(complex),字符串(string)和布尔值(bool).
-
整形(int)
Python的整形几乎没有长度限制,可以输入任意大小的数值。这取决于系统内存的限制,基本想要多大值就可以多大。这点和C#极为不一样,C#中即使是long,它的取值范围也都是有限的,最大也就是2^63 - 1。
此外,对于其他进制的数值表现形式Python也是不一样的,主要区别在于不同进制数值的前缀,如下:
-
浮点数(float)
Python中浮点数没有float和double之分,全部都是双精度浮点数,统一使用float表示。同时也支持使用科学计数法表示,如下:
虽然Python对float的取值范围没有明确限制,但是大多数平台上会被实现为双精度64位浮点数,大部分情况下最大值大约为1.8 ⨉ 10^308,超过这个值就会被显示为inf.
-
复数(complex)
复数是由一个实数和一个虚数组合构成,表示为:real+imagj,其中 real 是实数部分,imag是虚数部分。然而C#中没有复数的概念,只能自己封装构造。
老实讲,复数这块目前我还没实际使用到,对于其作用并没有太多的认知。
-
字符串(string)
字符串在Python中被表示为str,可以用单引号或者双引号包括一段内容来表示。大部分情况下单引号和双引号是没有去别的,但是当他们混用时,包括在字符串内的单引号或者双引号只会被当成普通符号。
转义符同样是受支持的,包括\",\n和\t之类的常用转义,甚至还包括\u表示任意Unicode字符。
关于字符串的格式化,Python中的str.format('{0}',arg)和从 3.7开始支持的'{0}'.format(arg)语法和C#中的string.Format("{0}",arg)的写法非常像。
-
布尔值(bool)
布尔值对于Python而言,和C#基本一致,只是Python中首字母大写而已,分别是True和False。对应的整形数字也都为1和0。
此外还要提一下空值,在Python中表示为None,而在C#中为null。使用起来没有太大区别
关于类型转换,在Python中整形、浮点数、复数、字符串和布尔值分别对应的方法为int(),float(),complex(),str(),和bool(),他们默认都支持了从其他类型强制转换的操作,如下:
但是对于C#而言,默认进行强制转换时,是不可以直接从字符串转换为对应值的,必须使用例如int.Parse()等方法显式转换才行。
变量
变量可以是任意的数据类型,在代码中使用一个变量名表示。变量名必须是大小写英文、数字和下划线(_)的组合,且不能由数字开头。虽然中文汉字也支持,但是一般不用中文作为变量名。这一点对Python和C#都适用,最大的不同在Python声明变量不需要指定变量类型,直接赋值就可以了。
Python解释器在赋值的时候,会干两件事情(以a='ABC‘举例):
- 在内存里创建变量内容,这里是字符串'ABC’
- 在创建一个名为a的变量,并将它指向‘ABC'的地址
这点和C#中的引用类型分配内存是类似的,变量会指向引用内容。
总结
关于Python的基础类型就介绍到这里,实际上使用基础类型时还会牵扯到一些内置的函数,比如abs,max,min,hex,oct,chr等。这些方便我们类型转换或者运算的内置方法推荐大家有空扫一下。