Python——变量和数据类型 港控/mmm° 2021-11-02 15:12 358阅读 0赞 [此系列摘抄自廖雪峰Python教程][Python] 目录链接: 1. [变量和数据类型][Link 1] 2. [list和tuple][list_tuple] 3. [条件语句和循环][Link 2] 4. [dict和set][dict_set] 5. [函数][Link 3] 6. [切片+迭代+生成器][Link 4] 7. [生成器和迭代器][Link 5] 8. [函数式编程][Link 6] 9. [模块][Link 7] 10. [面向对象编程][Link 8] 11. [面向对象高级编程][Link 9] 12. [定制类][Link 10] 13. [枚举类和元类][Link 11] 14. [错误及处理][Link 12] ## 一、基本数据类型 ## 1. Python 可以处理任意大小的整数,包括负整数。 2. 字符串是以 ‘ ’ 或 “ ” 括起来的任意文本。 3. 布尔值:True、False,可以用and、or、not运算(并、或、非)。 空值:None一、基本数据类型 ## 二、Print语句 ## 版本2.7和3.7会有所不同,旧版输出直接print xxxx 但是新版输出 print(xxxx)<仅此区别,下述皆遵循2.7> print 'hello, world'(2.7) print ('hello, world')(3.7) print语句也可以跟上多个字符串,用逗号“,”隔开,就可以连成一串输出,**打印时遇到逗号会输出一个空格**。 可以直接计算整数,例如: print 100 + 200 300 #运行结果 ## 三、注释 ## Python的**注释以 \# 开头**,后面的文字直到行尾都算注释。 例: # 这句话是个注释; 但这一句不是。 ## 四、什么是变量 ## 在计算机程序中,变量不仅可以是数字,还可以是任意数据类型。 在Python程序中,变量是用一个变量名表示,变量名必须是大小写英文、数字和下划线(\_)的组合,且不能用数字开头。 在Python中,等号=是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量。例如: a = 123 # a是整数 print a a = 'hello' # a变为字符串 print a 这种变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言。 变量的存储: 当我们写:a = 'ABC'时,Python解释器干了两件事情: 1.在内存中创建了一个'ABC'的字符串; 2.在内存中创建了一个名为a的变量,并把它指向'ABC'。 ## 五、Python中定义字符串 ## 定义字符串可以用 `''` 或 `""` 括起来表示。 当字符串中包含 单引号时 可以用 `""` 表示,同理字符串中有双引号时 可以用 `''` 表示。(小技巧) 转义:用 **转义字符`\`** 进行转义。`\' \"` \n 表示换行 \t 表示一个制表符 \\ 表示 \ 字符本身 ## 六、raw字符串与多行字符串 ## 如果一个字符串包含很多需要转义的字符,对每一个字符都进行转义会很麻烦。为了避免这种情况,我们可以在字符串前面加个前缀 `r`,表示这是一个 raw 字符串,里面的字符就不需要转义了。 例如:`r'\(~_~)/ \(~_~)/'` 但是`r'...'`表示法不能表示多行字符串,也不能表示包含'和 "的字符串(为什么?) 如果要表示多行字符串,可以用`'''...'''`表示: '''Line 1 Line 2 Line 3''' 等同于`'Line 1\nLine 2\nLine 3'` 还可以在多行字符串前面添加`r`,把这个多行字符串也变成一个raw字符串: r'''Python is created by "Guido". It is free and easy to learn. Let's start learn Python in imooc!''' ## 七、Unicode字符串 ## 为了统一所有文字的编码,Unicode应运而生。Unicode把所有语言都统一到一套编码里,这样就不会再有乱码问题了。 Unicode通常用两个字节表示一个字符,原有的英文编码从单字节变成双字节,只需要把高字节全部填为0就可以。 因为Python的诞生比Unicode标准发布的时间还要早,所以最早的Python只支持ASCII编码,普通的字符串'ABC'在Python内部都是ASCII编码的。 Python在后来添加了对Unicode的支持,以Unicode表示的字符串用`u'...'`表示,比如: print u'中文' 中文 如果中文字符串在Python环境下遇到 *UnicodeDecodeError*,这是因为.py文件保存的格式有问题。 可以在第一行添加注释 : `# -*- coding: utf-8 -*-` 目的是告诉Python解释器,用UTF-8编码读取源代码。然后用Notepad++ 另存为... 并选择UTF-8格式保存。 ## 八、整数和浮点数 ## Python的整数运算结果仍然是整数,浮点数运算结果仍然是浮点数: 1 + 2 # ==> 整数 3 1.0 + 2.0 # ==> 浮点数 3.0 但是整数和浮点数混合运算的结果就变成浮点数了: 1 + 2.0 # ==> 浮点数 3.0 ## 九、布尔类型 ## **只有True和False两个值,可以用and、or、not运算(并、或、非)。** 布尔类型还可以**与其他数据类型做 and、or和not运算**,例如 a = True print a and 'a=T' or 'a=F' **Python把0、空字符串''和None看成 False,其他数值和非空字符串都看成 True,**所以: True and 'a=T' 计算结果是 'a=T' 继续计算 'a=T' or 'a=F' 计算结果还是 'a=T' **短路计算:**(可以解释第3条) * 在计算 a and b 时,如果 a 是 False,则根据与运算法则,整个结果必定为 False,因此返回 a;如果 a 是 True,则整个计算结果必定取决与 b,因此返回 b。 * 在计算 a or b 时,如果 a 是 True,则根据或运算法则,整个计算结果必定为 True,因此返回 a;如果 a 是 False,则整个计算结果必定取决于 b,因此返回 b。 [Python]: https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000 [Link 1]: https://blog.csdn.net/Vici__/article/details/99548213 [list_tuple]: https://blog.csdn.net/Vici__/article/details/99548479 [Link 2]: https://blog.csdn.net/Vici__/article/details/99548654 [dict_set]: https://blog.csdn.net/Vici__/article/details/99548727 [Link 3]: https://blog.csdn.net/Vici__/article/details/99548818 [Link 4]: https://blog.csdn.net/Vici__/article/details/99548933 [Link 5]: https://blog.csdn.net/Vici__/article/details/99549025 [Link 6]: https://blog.csdn.net/Vici__/article/details/99549108 [Link 7]: https://blog.csdn.net/Vici__/article/details/99549240 [Link 8]: https://blog.csdn.net/Vici__/article/details/99549279 [Link 9]: https://blog.csdn.net/Vici__/article/details/99549421 [Link 10]: https://blog.csdn.net/Vici__/article/details/99549548 [Link 11]: https://blog.csdn.net/Vici__/article/details/99549664 [Link 12]: https://blog.csdn.net/Vici__/article/details/99549808
还没有评论,来说两句吧...