博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
入门第三课 Python中的变量,及数字、字符串详解
阅读量:6120 次
发布时间:2019-06-21

本文共 14124 字,大约阅读时间需要 47 分钟。

一、我们先以一道常见的小学数学题作为例子:

3x=6,那么x等于多少?

这里的x就成为“变量”。说白了就是一个“可变的”这么一个代号,只不过在编程语言中,习惯地称之为“变量”。相对应的一个数字10,就是一个常量,因为10这个数本身,是不变的。

二、在Python中,可以修改的值,我们统称为“变量”。与其他大多数编程语言相比,Python这里有所不同,那就是Python的变量不需要事先声明其类型。举个栗子-_-!

我们在IDLE界面中输入:x="I wanna learn Python!!!"

回车后,就意味着我们创建了一个变量x,他的值是一个字符串(字符串需要使用一对单引号或者一对双引号括起来),字符串的值是:I wanna learn Python!!!

>>> x="I wanna learn Python!">>> x'I wanna learn Python!'

变量的值有很多种类,可以给变量赋值一个数字,一串由数字、字母和符号混合体(称之为“字符串”),还可以是其他的很多东西(类型)。

分析一下:

1、只有一行代码;

2、功能一:创建变量x,该变量的名就是:x

     功能二:对其赋值,x的值是:I wanna learnPython

     功能三:设定了该变量的类型,x的类型是字符串类型

三、Pyhong中数据类型

        介绍数据类型之前,强调一下。对于首次看到的概念无法理解的,不用非得看懂,“记住”概念,一定要记住。之后的教程中会展开讲解,届时就能明白。这一点很重要,对于“为什么这么说”和“为什么这么设置”之类的问题,无需耗费时间思考。因为有的专有名词翻译其实没有什么实际的含义,而有的结果完全是Python故意设置成这样的。

我们的世界,有多重多样的信息:图书、音乐、影视剧、画。。。。在计算机看来都是一串数据。我们之前说过,要想让计算机为你服务,就要使用计算机能够读懂的语句与其交流。Python使用的数据可以大体分以下几种:

1、数字

2、字符串

3、列表

4、元组

5、字典

6、集合(目前我还没有用到,今后会补充)

 -------------------------------------------------------------------------------------------------------------------------------------------

1、数字:我们先看“数字”这个数据类型。这是与我们在数学中最为接近的概念。Python中的数字有:23、15.1432

比如:a=100,就意味着创建了一个变量a,a的值是100,因为100是整数,那么a是一个“整型”,在Python中称之为:int

           b=13.24,就意味着创建了一个变量b,b的值是13.24,因为13.24是整数+小数,那么b是一个“浮点型”,在Python中称之为:float  

           还有其他类型稍后做介绍

>>> a=10>>> type(a)
>>> b=23.50>>> type(b)

给变量a赋值10,是一个整数;创建后使用type()命令来显示变量的类型,这里显示为‘int’也就是整型。

给变量b赋值23.50,是一个浮点数;创建后使用type()命令来显示变量的类型,这里显示为‘float’也就是浮点型。

共数字使用的运算符号。数学中我们熟悉加减乘除,Python也有对应的运算方法和运算符号:

1.1 算术运算符

若a=10,b=21

+ 加 - 两个对象相加 a + b 输出结果 31
- 减 - 得到负数或是一个数减去另一个数 a - b 输出结果 -11
* 乘 - 两个数相乘或是返回一个被重复若干次的字符串 a * b 输出结果 210
/ 除 - x 除以 y b / a 输出结果 2.1
% 取模 - 返回除法的余数 b % a 输出结果 1
** 幂 - 返回x的y次幂 a**b 为10的21次方
// 取整除 - 返回商的整数部分 9//2 输出结果 4 , 9.0//2.0 输出结果 4.0

1.2 比较运算符

若a=10,b=20

== 等于 - 比较对象是否相等 (a == b) 返回 False。
!= 不等于 - 比较两个对象是否不相等 (a != b) 返回 True。
> 大于 - 返回x是否大于y (a > b) 返回 False。
< 小于 - 返回x是否小于y。所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。注意,这些变量名的大写。 (a < b) 返回 True。
>= 大于等于 - 返回x是否大于等于y。 (a >= b) 返回 False。
<= 小于等于 - 返回x是否小于等于y。 (a <= b) 返回 True。

1.3 赋值运算符

若a=10,b=20

= 简单的赋值运算符 c = a + b 将 a + b 的运算结果赋值为 c
+= 加法赋值运算符 c += a 等效于 c = c + a
-= 减法赋值运算符 c -= a 等效于 c = c - a
*= 乘法赋值运算符 c *= a 等效于 c = c * a
/= 除法赋值运算符 c /= a 等效于 c = c / a
%= 取模赋值运算符 c %= a 等效于 c = c % a
**= 幂赋值运算符 c **= a 等效于 c = c ** a
//= 取整除赋值运算符 c //= a 等效于 c = c // a

1.4 位运算符

        若a=60,b=13。这些数字是我们熟悉的,生活中我们都知道逢10进1,故而这些都是10进制数。计算机由于其固有的特性,计算机能读懂2进制、8进制和16进制等等的数字;只是这些数字的书写格式与我们熟悉的10进制完全不同。

a的值是60,二进制的a=00111100,b=00001101

& 按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0 (a & b) 输出结果 12 ,二进制解释: 0000 1100
| 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。 (a | b) 输出结果 61 ,二进制解释: 0011 1101
^ 按位异或运算符:当两对应的二进位相异时,结果为1 (a ^ b) 输出结果 49 ,二进制解释: 0011 0001
~ 按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1。~x 类似于 -x-1 (~a ) 输出结果 -61 ,二进制解释: 1100 0011, 在一个有符号二进制数的补码形式。
<< 左移动运算符:运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0。 a << 2 输出结果 240 ,二进制解释: 1111 0000
>> 右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数 a >> 2 输出结果 15 ,二进制解释: 0000 1111

1.5 逻辑运算符

若a=10,b=20

and x and y 布尔"与" - 如果 x 为 False,x and y 返回 False,否则它返回 y 的计算值。 (a and b) 返回 20。
or x or y 布尔"或" - 如果 x 是 True,它返回 x 的值,否则它返回 y 的计算值。 (a or b) 返回 10。
not not x 布尔"非" - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。 not(a and b) 返回 False

1.6 成员运算符

in 如果在指定的序列中找到值返回 True,否则返回 False。 x 在 y 序列中 , 如果 x 在 y 序列中返回 True。
not in 如果在指定的序列中没有找到值返回 True,否则返回 False。 x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。

1.7 身份运算符

身份运算符用于比较两个对象的存储单元

is is 是判断两个标识符是不是引用自一个对象 x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False
is not is not 是判断两个标识符是不是引用自不同对象 x is not y , 类似 id(a) != id(b)。如果引用的不是同一个对象则返回结果 True,否则返回 False。

注:  函数用于获取对象内存地址。

1.8 运算符的优先级

所谓优先级,就是指谁的优先级高,就先做谁的运算,反之亦然。以下表格列出了从最高到最低优先级的所有运算符:

运算符 描述
** 指数 (最高优先级)
~ + - 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@)
* / % // 乘,除,取模和取整除
+ - 加法减法
>> << 右移,左移运算符
& 位 'AND'
^ | 位运算符
<= < > >= 比较运算符
<> == != 等于运算符
= %= /= //= -= += *= **= 赋值运算符
is is not 身份运算符
in not in 成员运算符
not or and 逻辑运算符

 

 

2、字符串:所谓字符串,就是用一对儿单引号‘’或者一对儿双引号“”括起来的字符,在Python中称之为str。这些字符可以是一串字母“werGHJKemn”,可是一串数字“12649”或者一串标点符号“!@#¥%……”或者上述的混合体“qw567%%cx”。

这里有一个问题:

a=10

b=“10”

a与b相等吗?

答案:不相等。因为a是整型,b是字符串型。在python(以及计算机系统中),a和b是两个完全不同的变量。

另外,字符串可以收尾相连:

>>> a="What're you doing?"

>>> b="Leave me alone."
>>> c=a+b
>>> print(c)
What're you doing?Leave me alone.

数字可以加减乘除,字符串也有类似的多种操作,上面的示例就是两个字符串“相加”。下面详细说明:

2.1 想提取一个字符串中的一部分。举个栗子-_-!!

>>> a='Hello World!I wanna learn Python!I love Python!'>>> b=a[0]>>> b'H'>>> c=a[1:4]>>> c'ell'

分析一下:a是一个字符串。b从a取值,a后面[]中如果只有一个数字,就代表只从a中取一个字符,这个数字就是制定的顺序号,从0开始计数,则a[0]就是a中第一个字符,即'H'。

                                             c从a取值,a后面[]中如果有两个数字,且中间使用冒号隔开,就代表起点和终点(取值时不包括终点对应的字符,即不包含a[4]),所以返回了a[1]、a[2]和a[3]对应的字符‘ell’。

实际上这里的提取一部分,在Python中称之为“切片”,下面的列表中还会做详细的介绍。

2.2 字符串的运算符号。

+ 字符串连接 a + b 输出结果: HelloPython
* 重复输出字符串 a*2 输出结果:HelloHello
[] 通过索引获取字符串中字符 a[1] 输出结果 e
[ : ] 截取字符串中的一部分 a[1:4] 输出结果 ell
in 成员运算符 - 如果字符串中包含给定的字符返回 True 'H' in a 输出结果 1
not in 成员运算符 - 如果字符串中不包含给定的字符返回 True 'M' not in a 输出结果 1
r/R 原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思来使用,没有转义特殊或不能打印的字符。 原始字符串除在字符串的第一个引号前加上字母 r(可以大小写)以外,与普通字符串有着几乎完全相同的语法。
print( r'\n' ) print( R'\n' )
>>> a='Hello'>>> b='Python'>>> c=a+b>>> c'HelloPython'>>> d=a*2>>> d'HelloHello'>>> if a in d:        print('yes')    yes>>> if a not in b:        print('yes')    yes

2.3 输出字符串时,Python可以按照我们制定的格式输出:

>>> print('她是%s,今年%d岁'%('小霞',20))她是小霞,今年20岁

格式是这样的:print('   '%())。

2.3.1 其中单引号中是要打印的内容。这里需要被后面一对儿单括号中内容做替代的,使用%和一个代码来制定,比如%s和%d

2.3.2 后面一对儿单括号中的内容,是用来替代前面单引号中标有%s或者%d,这里使用了‘小霞’和20。因为%s指定的是字符串,%d指定的是整数。必须按照前后顺序指定值。

       %c  格式化字符及其ASCII码
      %s  格式化字符串
      %d  格式化整数
      %u  格式化无符号整型
      %o  格式化无符号八进制数
      %x  格式化无符号十六进制数
      %X  格式化无符号十六进制数(大写)
      %f  格式化浮点数字,可指定小数点后的精度
      %e  用科学计数法格式化浮点数
      %E  作用同%e,用科学计数法格式化浮点数
      %g  %f和%e的简写
      %G  %f 和 %E 的简写
      %p  用十六进制数格式化变量的地址

格式化辅助指令

* 定义宽度或者小数点精度
- 用做左对齐
+ 在正数前面显示加号( + )
<sp> 在正数前面显示空格
# 在八进制数前面显示零('0'),在十六进制前面显示'0x'或者'0X'(取决于用的是'x'还是'X')
0 显示的数字前面填充'0'而不是默认的空格
% '%%'输出一个单一的'%'
(var) 映射变量(字典参数)
m.n. m 是显示的最小总宽度,n 是小数点后的位数(如果可用的话)

2.4 针对字符串有很多函数:

1)capitalize()

将字符串的第一个字符转换为大写。

>>> a='tech'>>> a.capitalize()'Tech'

 2)center(width, fillchar)

返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。

>>> a='abcd'>>> a.center(20)'        abcd        '>>> b='abcd'>>> b.center(20,'1')'11111111abcd11111111'

3)count(str, beg= 0,end=len(string))

返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定,则返回指定范围内 str 出现的次数。

>>> a='abc'>>> b='abcabcabcdef'>>> b.count(a)3>>> b.count(a,1,10)2

4)encode(encoding='UTF-8',errors='strict')

以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'。

encode与下面一条的decode是互逆的操作。一起来看示例:

>>> a='我要学Python'>>> a_utf8=a.encode("UTF-8")>>> a_utf8b'\xe6\x88\x91\xe8\xa6\x81\xe5\xad\xa6Python'>>> a_gbk=a.encode("GBK")>>> a_gbkb'\xce\xd2\xd2\xaa\xd1\xa7Python'>>> a_utf8.decode('UTF-8','strict')'我要学Python'>>> a_gbk.decode('GBK','strict')'我要学Python'

分析一下:a是一个字符串变量,值是:我要学Python。这个值是人类的语言,有中文,也有英文。计算机根据不同的编码规则,有不同的编码供计算机系统来识别。这里使用了两套编码规则:UTF-8和GBK。

encode就是把人类语言转换为计算机能识别的语言,decode反过来是把计算机可以识别的语言转换为人类能识别的语言。

格式:encode和decode都有两个参数,一个是编码规则,另一个是错误处理方案。

5)bytes.decode(encoding="utf-8", errors="strict")

Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。

请见上一条。

6)endswith(b, beg=0, end=len(string))

检查字符串是否以b结束,如果beg 或者 end 指定则检查指定的范围内是否以b结束,如果是,返回 True,否则返回 False。

>>> a='123123123456'>>> b='123'>>> c='456'>>> a.endswith(b)False>>> a.endswith(c)True>>> a.endswith(c,0,5)False

7)expandtabs(tabsize=8)

把字符串 string 中的 tab 符号('\t')转为空格,tab 符号默认的空格数是 8 。

>>> a='There is a tab\t here.'>>> a'There is a tab\t here.'>>> a.expandtabs(0)'There is a tab here.'>>> a.expandtabs(20)'There is a tab       here.'

8)find(str, beg=0 end=len(string))

检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1。

>>> a='abc'>>> b='abcabcabcdef'>>> b.find(a)0>>> b.find(a,1,10)3>>> c='xyz'>>> b.find(c)-1

9)index(b, beg=0, end=len(string))

跟find()方法一样,只不过如果b不在字符串中会报一个异常。

>>> a='123123123asd'>>> b='123asd'>>> c='789'>>> a.index(b)6>>> a.index(c)Traceback (most recent call last):  File "
", line 1, in
a.index(c)ValueError: substring not found>>> a.index(b,0,5)Traceback (most recent call last): File "
", line 1, in
a.index(b,0,5)ValueError: substring not found

10)isalnum()

如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False。

>>> a='1234sdfgf'>>> a.isalnum()True>>> b='234@#$%sdf'>>> b.isalnum()False

11)isalpha()

如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False。

>>> a='adsfb'>>> a.isalpha()True>>> b='adf2'>>> b.isalpha()False

12)isdigit()

如果字符串只包含数字则返回 True 否则返回 False。

>>> a='1234'>>> a.isdigit()True>>> b='e43'>>> b.isdigit()False

13)islower()

如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False。

>>> a='adfga'>>> a.islower()True>>> b='asdf23A'>>> b.islower()False

14)isnumeric()

如果字符串中只包含数字字符,则返回 True,否则返回 False。

>>> a='2345'>>> a.isnumeric()True>>> b='234sdf'>>> b.isnumeric()False

15)isspace()

如果字符串中只包含空白,则返回 True,否则返回 False。

>>> a='   '>>> a.isspace()True>>> b='  a12'>>> b.isspace()False

16)istitle()

检测字符串中所有的单词拼写首字母是否为大写,且其他字母为小写。是则返回 True,否则返回 False。

>>> a='There is a bug!'>>> b='There is A bug!'>>> a.istitle()False>>> b.istitle()False>>> c='There Is A Bug!'>>> c.istitle()True

17)isupper()

如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False。

>>> a='123#_A$%'>>> a.isupper()True>>> b='345a'>>> b.isupper()False

18)join(seq)

以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串。

>>> a'abc'>>> b='xyz'>>> a.join(b)'xabcyabcz'

19)len(string)

返回字符串长度。

>>> a'abcABC'>>> len(a)6

20)ljust(width[, fillchar])

返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。

>>> a='abc'>>> a.ljust(20)'abc                 '>>> b='xyz'>>> b.ljust(20,'1')'xyz11111111111111111'

21)lower()

转换字符串中所有大写字符为小写.

>>> a'abcABC'>>> a.lower()'abcabc'

22)lstrip()

截掉字符串左边的空格或指定字符。

>>> a='   ad23'>>> a.lstrip()'ad23'

23)title()

返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写。

>>> a='I wanna learn Py.'>>> a.title()'I Wanna Learn Py.'

24)max(str)

返回字符串 str 中最大的字母。

>>> a'abcABC'>>> max(a)'c'

25)min(str)

返回字符串 str 中最小的字母。

>>> a='abcABC'>>> min(a)'A'

26)replace(old, new [, max])

把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。

>>> a='abcabcabcabc'>>> a.replace('abc','xyz',2)'xyzxyzabcabc'

27)rfind(str, beg=0,end=len(string))

类似于 find()函数,不过是从右边开始查找。

>>> a='abc'>>> b='abcabcxyzabc'>>> b.rfind(a)9>>> b.rfind(a,0,11)3>>> b.rfind(a,0,9)3>>> b.rfind(a,0,8)3>>> b.rfind(a,0,7)3>>> b.rfind(a,0,5)0

28)rindex( str, beg=0, end=len(string))

类似于 index(),不过是从右边开始。

>>> a='abc'>>> b='abcabcxyzabc'>>> b.rindex(a)9>>> b.rindex(a,0)9>>> b.rindex(a,0,5)0>>> b.rindex(a,0,7)3

29)rjust(width,[, fillchar])

返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串。

>>> a='abc'>>> a.rjust(20)'                 abc'>>> b='xyz'>>> b.rjust(20,'1')'11111111111111111xyz'

30)rstrip()

删除字符串字符串末尾的空格.

>>> a='tech   '>>> a'tech   '>>> a.rstrip()'tech'

31)split(b, num)

num=string.count(b)) 以b为分隔符截取字符串,如果 num 有指定值,则仅截取 num 个子字符串。

b -- 分隔符,默认为所有的空字符,包括空格、换行(\n)、制表符(\t)等。

num -- 分割次数,默认全部分割。

>>> a='I wanna learn Python!'>>> a.split()['I', 'wanna', 'learn', 'Python!']>>> a.split('a')['I w', 'nn', ' le', 'rn Python!']>>> a.split('a',1)['I w', 'nna learn Python!']

32)splitlines([b])

按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 b 为 False,不包含换行符,如果为 True,则保留换行符。

>>> a='abc\nde\n\n  fg\r\nhi\r'>>> a.splitlines()['abc', 'de', '', '  fg', 'hi']>>> a.splitlines(True)['abc\n', 'de\n', '\n', '  fg\r\n', 'hi\r']

33)startswith(b, beg=0,end=len(string))

检查字符串是否是以b开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。

>>> a='asdfasdfasdf'>>> b='asdf'>>> c='a123'>>> a.startswith(b)True>>> a.startswith(c)False>>> d='as1'>>> a.startswith(d,4,8)False

34)strip([chars])

在字符串上执行 lstrip()和 rstrip()。

>>> a='          asdfer123            '>>> a.strip()'asdfer123'

35)swapcase()

将字符串中大写转换为小写,小写转换为大写。

>>> a='Tech'>>> a.swapcase()'tECH'

36)bytearray.maketrans()

 还不会用,以后补充。-_-!!

37)bytes.maketrans()

>>> tran=bytes.maketrans(b'abcde',b'12345')>>> a='I wanna learn Py.'>>> b'I wanna learn Py.'.translate(tran,b'n')b'I w11 l51r Py.'>>> b'I wanna learn Py.'.translate(tran)b'I w1nn1 l51rn Py.'

38)str.maketrans(intab,outtab)

maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。两个字符串的长度必须相同,为一 一对应的关系。返回字符串转换后生成的新字符串。

intab -- 字符串中要替代的字符组成的字符串。

outtab -- 相应的映射字符的字符串。

>>> intab="abcde">>> outtab="12345">>> tran=str.maketrans(intab,outtab)>>> a='I wanna learn Py.'>>> a.translate(tran)'I w1nn1 l51rn Py.'

分析一下:通过str.maketrans制定对应规则tran:a-1/b-2/c-3/d-4/e-5。

之后就可以通过translate应用对应规则tran来“翻译”啦。

39)translate(table, deletechars="")

根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中。

见38示例。

不同的是,由bytes.maketrans()和bytearray.maketrans()制定的对应规则,translate在使用时,可以指定要删除的字符。

>>> tran=bytes.maketrans(b'abcde',b'12345')>>> a='I wanna learn Py.'>>> b'I wanna learn Py.'.translate(tran,b'n')b'I w11 l51r Py.'>>> b'I wanna learn Py.'.translate(tran)b'I w1nn1 l51rn Py.'

40)upper()

转换字符串中的小写字母为大写。

>>> a='tech'>>> a.upper()'TECH'

41)zfill (width)

返回长度为 width 的字符串,原字符串右对齐,前面填充0。

>>> a='asdf'>>> a.zfill(20)'0000000000000000asdf'

42)isdecimal()

检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。

>>> a='adsf'>>> a.isdecimal()False>>> b='1233'>>> b.isdecimal()True

2.5 转义字符

这个怎么说呢?举个栗子-_-!!

我想打印两行字:大体的格式这样滴

I wanna

learn Python!

我可以这样编程:

>>> print('I wanna');print('learn Python!')I wannalearn Python!

还可以这样:

>>> print('I wanna\nlearn Python!')I wannalearn Python!

你可能会说:不是说print('xxxx'),python会打印xxxx吗?怎么到你这里不仅没有打印中间的\n,还换了行?

这里就涉及到“转义字符”这个概念。所谓转义字符,就是指在python中,有特殊含义的字符或字符串(多个字符连在一起)。都有哪些呢?一起看一下:

\(在行尾时) 续行符
\\ 反斜杠符号
\' 单引号
\" 双引号
\a 响铃
\b 退格(Backspace)
\e 转义
\000
\n 换行
\v 纵向制表符
\t 横向制表符
\r 回车
\f 换页
\oyy 八进制数,yy代表的字符,例如:\o12代表换行
\xyy 十六进制数,yy代表的字符,例如:\x0a代表换行
\other 其它的字符以普通格式输出

表格中清楚地标明了在python中特殊字符和字符串,代表着特殊的含义。比如刚才我们使用的\n,就代表换行,也就是另起一行!!

3、列表

Python中列表十分常见,格式是一对方括号括起来的数据。在Python中称之为list。注意一点,列表可以修改。

3.1方括号中可以存放数字,比如:

[1,2,3,4,100]

3.2可以存放字符串,比如:

[“25”,"sdfer"]

3.3也可以存放列表,比如:

[[1,2,3,5],["sd","567"]]

3.4或者上述类型的混合体

4、元祖

格式与列表(list)相同,唯一不同的地方是,元祖不能修改。在Python中称之为tuple。

5、字典

在Python中称之为dict。

使用一对大括号{}括起来的数据。

我们都使用过字典。无论是中文字典还是英语字典,都有一个共同特性:那就是根据目录,找出对应的页数;再根据页码找到我们想看的内容。

Python中的字典也是这样的。无非就是叫法有所不同。

举个栗子-_-!!

{"name":"zhaoyun","age":35,"height":185,"weight":85,"addr":"beijing:}

分析一下:

5.1 数据成对儿出现"name":"zhaoyun",中间用冒号隔开,意思是name是zhaoyun。

5.2 name称为“键”,zhaoyun称为“值”。

5.3 对儿与对儿之间使用逗号隔开。

 

转载于:https://www.cnblogs.com/tuobeiwoniu/p/8648402.html

你可能感兴趣的文章
webpack学习笔记(六)优化
查看>>
Nginx unit 源码安装初体验
查看>>
PTA基础编程题目集6-2多项式求值(函数题)
查看>>
哈佛医生帮你增强记忆力
查看>>
Cloudera Search配置
查看>>
[原译]类型安全的黑板模式(属性包)
查看>>
【转】python中的一维卷积conv1d和二维卷积conv2d
查看>>
Linux两台主机之间建立信任(ssh免密码)
查看>>
re,hashlib模块
查看>>
Android之文件数据存储
查看>>
Android 双击返回键退出程序 实现
查看>>
javascript中的设计模式
查看>>
基础回顾数组
查看>>
ubantu 黑屏
查看>>
sqlserver 清空数据 主键从1开始
查看>>
Spark RDD Transformation 简单用例(二)
查看>>
全国各省市县 人口密度 数据 下载 空间数据 高精度 空间分布数据 多年 人口热力图 地理信息 GIS...
查看>>
微信支付的安全漏洞之XXE
查看>>
C#多线程参数传递.cs
查看>>
Acceptor 和 Connector
查看>>