语言元素
语言元素
共勉
不要哀求,学会争取。若是如此,终有所获。
前言
之前的文章中,我们已经对 Python 有所了解了,并且也学会了 Pycharm 的安装及使用。现在该开始正式进入主题了,接下来就要学习 Python 的相关语法,以及如何使用他们进行编程。
今天主要内容就介绍 Python 中的如下知识点:
- 变量
- 数据类型
- 运算符
变量
什么是变量
所谓变量,其实一开始是源自于数学。而在计算机语言中,变量指的是 能够存储计算结果或者能够表示值的抽象概念。
我们可以通过变量名来访问变量,在 Python 中,变量通常是可变的,它不仅仅能够表示数字,还能是任意数据类型。
变量命名规则
Python 中,是通过标识符来给变量命名,而标识符就是用于给程序中变量、类、方法命名的符号。简单来说,标识符就是合法的名字。而什么是合法的名字呢?那我们就来看看 Python 中标识符的命名规则。
Python 中,标识符 必须以字母、下划线开头,然后后面可以跟上任意数目的字母、数字以及下划线,而且也区分大小写。总结起来就是如下几点:
变量名只能包含字母、数字和下划线,而且只能以字母或下划线开头,不能以数字开头,比如我们可以把一个变量命名为
cunyu_1943、_cunyu1943
但是不能命名为1943_cunyu
;变量名中间不能包含空格,但是可以用下划线来进行分割,比如可以命名为
student_name
,但不能命名为student name
;变量名应该尽量简短切具有描述性,比如我们变量名为
name
,那别人一看就知道这是表示名字的,但如果我们命名为n
,那可能就得花更多的时间来搞清楚它到底是啥意思;不要把 Python 中的关键字和内置函数名用做变量名,Python 中常见的关键字和内置函数如下表;
关键字 | 描述 |
---|---|
and | 逻辑运算符 |
as | 创建别名 |
assert | 用于调试 |
break | 跳出循环 |
class | 定义类 |
continue | 继续循环的下一个迭代 |
def | 定义函数 |
del | 删除对象 |
elif | 在条件语句中使用,等同于 else if |
else | 用于条件语句 |
except | 处理异常,发生异常时如何执行 |
False | 布尔值,比较运算的结果 |
finally | 处理异常,无论是否存在异常,都将执行一段代码 |
for | 创建 for 循环 |
from | 导入模块的特定部分 |
global | 声明全局变量 |
if | 写一个条件语句 |
import | 导入模块 |
in | 检查列表、元组等集合中是否存在某个值 |
is | 测试两个变量是否相等 |
lambda | 创建匿名函数 |
None | 表示 null 值 |
nonlocal | 声明非局部变量 |
not | 逻辑运算符 |
or | 逻辑运算符 |
pass | null 语句,一条什么都不做的语句 |
raise | 产生异常 |
return | 退出函数并返回值 |
True | 布尔值,比较运算的结果 |
try | 编写 try...except 语句 |
while | 创建 while 循环 |
with | 用于简化异常处理 |
yield | 结束函数,返回生成器 |
内置函数 | ||||
---|---|---|---|---|
abs() | delattr() | hash() | memoryview() | set() |
all() | dict() | help() | min() | setattr() |
any() | dir() | hex() | next() | slice() |
ascii() | divmod() | id() | object() | sorted() |
bin() | enumerate() | input() | oct() | staticmethod() |
bool() | eval() | int() | open() | str() |
breakpoint() | exec() | isinstance() | ord() | sum() |
bytearray() | filter() | issubclass() | pow() | super() |
bytes() | float() | iter() | print() | tuple() |
callable() | format() | len() | property() | type() |
chr() | frozenset() | list() | range() | vars() |
classmethod() | getattr() | locals() | repr() | zip() |
compile() | globals() | map() | reversed() | __import__() |
complex() | hasattr() | max() | round() |
数据类型
要处理各种文本、图形、音频、视频等数据,光使用数值类型是远远不够的,我们需要更多的数据类型来定义不同的数据。在 Python 中,主要有如下几种数据类型:
数字
数字数据类型用于存储数值,他们是 不可改变 的数据类型。也就是说,每改变一个数字数据类型,就会分配一个新的对象。
当我们给变量指定一个值时,数字对象就会被创建,而如果我们要删除这些对象的引用,就可以使用 del
语句;
# 创建对象
number = 1
# 删除引用
del number
Python 支持如下不同的数字类型;
int
:整型(⚠️ Python 2.x 中有int
和long
之分,但是 Python 3.x 中只有int
),能够处理任意大小的整数,而且支持常见的二进制、八进制、十进制以及十六进制;float
:浮点类型,也就是数学中的小数。一个浮点数的小数点位置是可变的,它不仅可以表示成数学写法(456.78
),还支持科学记数法(4.5678e2
);complex
:复数类型,由实部和虚部组成,形如a + bj
的形式,和数学中的复数表示一样,只是把i
变成了j
;
字符串
以单引号或双引号括起来的任意文本,例如 “cunyu1943”
和 ‘cunyu1943’
,而且还可以书写成多行的形式(用三个单引号或三个双引号开头,三个单引号或三个双引号结尾)
'''
公众号:村雨遥
blog:cunyu1943.site
'''
“”“
公众号:村雨遥
blog:cunyu1943.site
”“”
Python 中字符串有 2 种取值顺序:
- 从左向右索引,索引值从
0
开始,最大索引值是字符串长度减1
; - 从右向左索引,索引值从
-1
开始,最大索引值是字符串开头;
如果我们要从字符串汇总获取一小段子字符串,则可以使用 [头下标:尾下标]
来进行截取。注意 左闭右开 原则,即通过 [头下标:尾下标]
方式获取的子字符串包含头下标的字符,但不包含尾下标的字符;
加入我们的字符串 s = 'abcdef’
,则通过不同方式索引的结果如下图:
列表
list
是一种 有序 的集合,能随时向其中添加和删除元素,用 []
标识,内部元素用逗号隔开,元素可以是字符、数字、字符串等数据类型,是 Python 中最常用的复合数据类型。类似于字符串,也可以用 [头下标:尾下标]
的方式来进行截取相应子列表,索引方式同字符串,示例如下:
list
中常用方法如下:
方法 | 说明 |
---|---|
len(list) | 列表元素个数 |
list(seq) | 将元组转换为列表 |
list.pop() | 删除 list 末尾的元素 |
list.pop(index) | 删除 list 中索引位置为 index 的元素 |
list.append(obj) | 在列表末尾添加新的对象 |
list.count(obj) | 统计某个元素在列表中出现的次数 |
list.insert(index, obj) | 将对象插入列表指定位置 |
list.remove(obj) | 移除列表中某个值的第一个匹配项 |
list.reverse() | 反转列表中元素 |
list.index(obj) | 从列表中找出某个值第一个匹配项的索引位置 |
list.sort(cmp=None, key=None, reverse=False) | 对原列表进行排序,reverse = True 降序, reverse = False 升序(默认) |
如果我们要实现不同列表连接,应该这么办呢,此时我们可以使用 +
来连接不同的数组;
>>> list1 = [1, 2, 3]
>>> list2 = [4, 5, 6]
>>> print(list2 + list2)
[1, 2, 3, 4, 5, 6]
而如果我们想要某个列表重复,则可以使用 *
;
>>> list1 = [1, 3, 4]
>>> print(list1 * 2)
[1, 3, 4, 1, 3, 4]
元组
tuple
也是一种类似于 list
的 有序 列表,用 ()
标识,内部元素用逗号隔开。它俩的一个最大区别在于: tuple
一旦初始化之后,就不能再修改了,相当于只读列表,所以 tuple
不像 list
一样有类似 append()、insert()
等方法;
常用方法如下:
方法 | 说明 |
---|---|
len(tuple) | 计算元组元素个数 |
tuple(seq) | 将列表转换为元组 |
max(tuple) | 返回元组中元素最大值 |
min(tuple) | 返回元组中元素最小值 |
如果我们要定义一个空的元组,可以用如下的方式:
tuple = ()
而如果元组中只有一个元素时,为了避免歧义,通常需要定义成如下形式:
t = (1,)
字典
列表是有序的对象集合,而字典则是无序的对象集合,字典用 {}
标识,元素间用逗号分隔,每个元素由 key:value
的形式组成。
两者之间的区别在于:字典中的元素是通过键值对来存取的,而不是通过偏移存取。
字典值虽然能够没有限制,但是键是有限制的,主要有如下两点需要记住:
- 不允许同一个键出现两次;
- 键必须不可变,所以它可以是数字、字符串或元组,但是不能用列表;
字典也有许多方法供我们使用,主要方法总结如下:
方法 | 说明 |
---|---|
len(dict) | 计算字典元素个数,即键的总数 |
str(dict) | 输出字典可打印的字符串表示 |
type(variable) | 返回输入的变量类型,如果变量是字典就返回字典类型 |
dict.clear() | 删除字典内所有元素 |
dict.copy() | 返回一个字典的浅复制 |
dict.haskey(key) | 如果键在字典 dict 里返回 True ,否则返回 False |
dict.get(key) | 返回指定键的值 |
dict.keys() | 以列表返回一个字典所有的键 |
dict.values() | 以列表返回字典中的所有值 |
dict.items() | 以列表返回可遍历的(键, 值) 元组数组 |
pop(key) | 删除字典给定键 key 所对应的值,返回值为被删除的值 |
popitem() | 返回并删除字典中的最后一对键和值 |
布尔值
布尔值只有True
、False
两种值,要么是True
,要么是False
。在Python中,可以直接用True
、False
直接表示布尔值,也可以通过布尔运算计算出来。
>>> False
False
>>> 3 > 2
True
运算符
Python 支持多种运算符,但是运算符之间也是有优先级的,下表大致按照优先级从高到低的顺序列出了所有运算符,下面分别介绍运算符的类别;
运算符 | 描述 |
---|---|
** | 指数 (最高优先级) |
~ + - | 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@) |
* / % // | 乘,除,取模和取整除 |
+ - | 加法减法 |
>> << | 右移,左移运算符 |
& | 位 'AND ' |
`^ | ` |
<= < > >= | 比较运算符 |
<> == != | 等于运算符 |
= %= /= //= -= += *= **= | 赋值运算符 |
is is not | 身份运算符 |
in not in | 成员运算符 |
not and or | 逻辑运算符 |
算术运算符
假设变量 a = 10, b = 20
:
运算符 | 描述 | 实例 |
---|---|---|
+ | 加 - 两个对象相加 | a + b 输出结果 30 |
- | 减 - 得到负数或是一个数减去另一个数 | a - b 输出结果 -10 |
* | 乘 - 两个数相乘或是返回一个被重复若干次的字符串 | a * b 输出结果 200 |
/ | 除 - x 除以 y | b / a 输出结果 2 |
% | 取模 - 返回除法的余数 | b % a 输出结果 0 |
** | 幂 - 返回 x 的 y 次幂 | a**b 为 10 的 20 次方, 输出结果 100000000000000000000 |
// | 取整除 - 返回商的整数部分(向下取整) | >>> 9//2 4 >>> -9//2 -5 |
比较运算符
假设变量 a = 10, b = 20
:
运算符 | 描述 | 实例 |
---|---|---|
== | 等于 - 比较对象是否相等 | (a == b) 返回 False |
!= | 不等于 - 比较两个对象是否不相等 | (a != b) 返回 True |
<> | 不等于 - 比较两个对象是否不相等。python3 已废弃。 | (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 |
赋值运算符
假设变量 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 |
逻辑运算符
假设变量 a = 10, b = 20
:
运算符 | 逻辑表达式 | 描述 | 实例 |
---|---|---|---|
and | x and y | 布尔"与" - 如果 x 为 False ,x and y 返回 False ,否则它返回 y 的计算值 | (a and b) 返回 20 |
or | x or y | 布尔"或" - 如果 x 是非 0,它返回 x 的值,否则它返回 y 的计算值 | (a or b) 返回 10 |
not | not x | 布尔"非" - 如果 x 为 True ,返回 False 。如果 x 为 False ,它返回 True | not(a and b) 返回 False |
位运算符
假设变量 a = 60, b = 13
:
按位运算符石将数字转换为二进制之后来进行计算的,则 a = 00111100、b = 00001101
运算符 | 描述 | 实例 |
---|---|---|
& | 按位与运算符:参与运算的两个值,如果两个相应位都为 1,则该位的结果为 1,否则为 0 | (a & b) 输出结果 12 ,二进制解释: 0000 1100 |
` | ` | 按位或运算符:只要对应的二个二进位有一个为 1 时,结果位就为 1 |
^ | 按位异或运算符:当两对应的二进位相异时,结果为 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 |
成员运算符
运算符 | 描述 | 实例 |
---|---|---|
in | 如果在指定的序列中找到值返回 True ,否则返回 False 。 | x 在 y 序列中 , 如果 x 在 y 序列中返回 True |
not in | 如果在指定的序列中没有找到值返回 True ,否则返回 False 。 | x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True |
身份运算符
身份运算符用于比较两个对象的存储单元:
运算符 | 描述 | 实例 |
---|---|---|
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 |
总结
好了,文章到这里也算🈶️挺多内容了,赶紧去仔细看看,然后动手实践起来吧。
如果你觉得我的文章对你有所帮助,那就赶紧去关注我吧。另外,为了方便大家交流,我还特意创建了微信交流群,如果你也有兴趣加入,关注我的公众号(村雨遥)回复 加群,我人工拉你入群哦。
⏳ 联系
想解锁更多知识?不妨关注我的微信公众号:村雨遥(id:JavaPark)。
扫一扫,探索另一个全新的世界。