zoukankan      html  css  js  c++  java
  • 写给.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,可以用单引号或者双引号包括一段内容来表示。大部分情况下单引号和双引号是没有去别的,但是当他们混用时,包括在字符串内的单引号或者双引号只会被当成普通符号。

      转义符同样是受支持的,包括", 和 之类的常用转义,甚至还包括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‘举例):

    1. 在内存里创建变量内容,这里是字符串'ABC’
    2. 在创建一个名为a的变量,并将它指向‘ABC'的地址

    这点和C#中的引用类型分配内存是类似的,变量会指向引用内容。

    总结


     

    关于Python的基础类型就介绍到这里,实际上使用基础类型时还会牵扯到一些内置的函数,比如abs,max,min,hex,oct,chr等。这些方便我们类型转换或者运算的内置方法推荐大家有空扫一下。

  • 相关阅读:
    Gym102501G Swapping Places(拓扑排序)
    2019SWERC题解
    CF364D Ghd(随机化)
    CF500E New Year Domino(并查集+栈)
    CF280C Game on Tree(期望)
    CF1093G Multidimensional Queries(线段树)
    CF677D Vanya and Treasure(最短路)
    CF788C The Great Mixing(最短路)
    queryset高级用法:prefetch_related
    queryset高级用法:select_related
  • 原文地址:https://www.cnblogs.com/mantgh/p/13341918.html
Copyright © 2011-2022 走看看