Python学习笔记整理Module1

2018-11-22 08:44:58来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

  • 编程语言介绍

  • Python介绍
  • Python安装
  • 第一个Python程序
  • 变量
  • 程序交互
  • 格式化输出
  • 数据运算
  • 数据类型
  • 控制流程
  • 进制与字符编码

编程语言介绍

编程语言的定义及作用:

编程的定义:‘动词’即写代码。

编程的作用:让计算机以人类的思维执行某些事件。

编程语言的分类:

  1. 机器语言
  2. 汇编语言
  3. 高级语言

机器语言与汇编语言属于低级语言.

机器语言:由于计算机只能识别二进制码,因此用二进制码0和1描述的指令为机器指令。全部由机器指令集合构成的语言称之为机器语言。

  • 优点:执行速度快
  • 缺点:直观性差,学习困难

汇编语言:汇编语言的实质性是与机器语言相同的都是对计算机硬件进行操作。不同的是指令采用英文缩写的形式更方便记忆和识别。

高级语言:高级语言相比汇编语言,不但将许多相关的机器指令合成为单条指令,比并且去掉了许多与操作有关与完成工作无关的繁琐细节。例如堆栈,寄存器等。这样就大大的简化了程序中的机器指令,由于忽略了很多细节,so 学习起来更加方便,编程者也不需要太多的相关知识。

高级语言的分类:

  • 编译型
  • 解释型

编译型:在程序执行前。把源程序翻译成机器码。因此其目标程序可以脱离其语言环境独立运行。程序一旦修改,就必须修改源文件程序编译。

  • 优点:运行速度快,可脱离环境单独运行
  • 缺点:可移植性(跨平台)差,修改比较繁琐

解释型:目标程序由解释器翻译成机器语言才能执行,因此执行速度慢,且不可脱离环境单独运行,由于不需要提前翻译成机器语言,使用修改想比编译型的语言方便许多

  • 优点:可移植性强,修改方便
  • 缺点:运行速度慢,需要语言环境才能运行

Python介绍

Python介绍:

创始人:吉多 范罗苏姆(Guido van Rossum)

1989年圣诞节期间,Guido开始写Python语言编译器.他的初衷是创造一种c和shell之间简单易学,功能全面可扩展的语言

Python的发展史:

1991年:第一个Python编译器诞生

1994年:Python1.0

2000年:Python2.0

2004年:Python2.4同时Django诞生

2006年:Python2.5

2008年:Python2.6

2008年:Python3.0

2009年:Python3.1

2010年:Python2.7(过渡版本支持到2020年)同时支持2.x和3.x的特性

2011年:Python3.2

2012年:Python3.3

2014年:Python3.4

2015年:Python3.5

 

Python解释器:

  • CPython:

这个解释器是c语言开发的,所以叫cpython.在命令行下运行python就是启动cpython解释器

  • IPython:

Ipython是基于cpython之上的一个交互式解释器,也是就说,ipython只是在交互上有所增强,但只是代码是和cpytho完全一样的。

  • Pypy:

pypy是另一个python解释器,它的目标是执行速度。pypy采用JIT技术,对python代码进行动态编译,所以可以显著提高python代码执行速度.

  • Jython:

Jython是运行在Java平台上的python解释器,可以直接把python代码编译成Java字节码执行.

  • IronPython:

IronPython和Jython类似,只不过ironpython是运行在微软.net平台上的python解释器,可以直接把python代码编译成.net字节码

Python安装:

下载地址:https://www.python.org/downloads/windows/

Windows:

默认下一步

验证是否安装成功:win+r 输入cmd 出现以下字符即表明安装成功

C:\Users\67525>python
Python 3.6.6 (v3.6.6:4cf1f54eb7, Jun 27 2018, 03:37:03) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>>

错误提示:不是内部命令

解决办法:配置path环境

计算机(此电脑)鼠表右键 --> 属性 --> 高级系统设置 -->高级 (环境变量) --> 在path中添加 Python的安装路径

 

Linux or Mac:

一般自带Python2.7 or Python2.6,需要可其他版本自行安装。

安装其他版本已python3.6为例:

需要先下载python3.6.的源码包

 

# tar -zxvf Python-3.6.1.tgz
# cd Python-3.6.1
# ./configure
# make && make instal

 

检查是否安装成功:

# python3 -V
Python 3.6.1

 

第一个Pthon程序

1.新建文件Hello.py 编辑以下内容:O

1 print('Hello World!')

在cmd下输入 Python Hello.py

2.在Python交互器下

 

D:\>python
Python 3.6.6 (v3.6.6:4cf1f54eb7, Jun 27 2018, 03:37:03) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> print('hello world')
hello world
>>>

 

变量:

变量的作用:就是把程序运算的中间结果存放到内存里,以便后面的代码继续调用

变量名的定义规则:

  1. 变量名是字母下划线及数字的任意组和
  2. 变量名的首位字符不可为数字
  3. 以下关键字不可以用作变量名

定义变量名要避免的几种方式:

  1. 变量名为中文或拼音
  2. 变量名过长
  3. 变量名词不达意

变量的赋值

1 number = 5
2 name = 'xuange'

变量的命名习惯

#驼峰体
AgeOfOldBoy = 56
NumberOfStudents = 80
#下划线
age_of_oldboy = 56
number_of_studnets = 80

常量

常量:即不可变得量,在Python中并没有特定的语法来声明常量,只需把常量名全部使用大写即可.

常量的定义:

PI = 3.1415826
print(PI)

用户交互及注释

作用:接收用户输入的值,默认类型为字符串

语法:

 

#语法
name = input('name:')

 

特定条件下需要接收密码可用模块中的getpass模块

import getpass
passwd = getpass.getpass('passwd:')

注释

#这是单行注释
'''
这是多行注释
'''

注释原则:只需要在不容易理解的地方加入注释即可,不需要全部都加注释。可以使用中文或者英文,禁止使用拼音

格式化输出

作用:按照指定格式打印内容。

占位符:

  1. %s 字符串类型
  2. %d 数字类型
  3. %f 浮点数类型

常见的三种字符串格式方式:

 1 ##常见的几种方法
 2 name = input('Name:')
 3 age = input('Age:')
 4 job = input('Jbo:')
 5 salary = input('Salary:')
 6 #方法一
 7 info = '''
 8 -------info %s -------
 9 Name: %s
10 Age: %s
11 Job: %s
12 Salary: %s
13 ------ the end ---------
14 ''' % (name, name, age, job, salary)
15 print(info)
16 # 方法二
17 info = '''
18 ----- info {_name}
19 Name: {_name}
20 Age: {_age}
21 Job: {_job}
22 Salay: {_salary}
23 '''.format(_name=name, _age=age, _job=job, _salary=salary)
24 print(info)
25 #方法三
26 info  = '''
27 ------info {0} ----
28 Name :{0}
29 Age:{1}
30 Job:{2}
31 Salary: {3}
32 ''' .format(name, age, job, salary)
33 print(info)
34 #一种缩写
35 b = 'bbb'
36 print(f'aaaa{b}')

数据运算

  • 算数运算符
  • 比较运算符
  • 赋值运算符
  • 逻辑运算符
  • 成员运算
  • 身份运算
  • 位运算

算数运算符

 1 #例子:
 2 >>> a = 10
 3 >>> b = 5
 4 >>> c = a+b
 5 >>> c
 6 15
 7 >>> c = a-b
 8 >>> c
 9 5
10 >>> c = a*b
11 >>> c
12 50
13 >>> c = a/b
14 >>> c
15 2.0
16 >>> c = a % b
17 >>> c
18 0
19 >>> c = a ** b
20 >>> c
21 100000
22 >>> c = a //b
23 >>> c
24 2

 

比较运算:

#例子:
>>> a = 5
>>> b = 3
>>> a == b
False
>>> a !=b
True
>>> a > b
True
>>> a < b
False
>>> a >= b
True
>>> a <= b
False
>>>

 

 

赋值运算

#

例子:
>>> a = 5
>>> b = 3
>>> b += a #b = b+a
>>> b
8
>>> b -= a #b= b-a
>>> b
3
>>> b *= a #b = b*a
>>> b
15
>>> b /= a #b = b/a
>>> b
3.0
>>> b %= a #b = b%a
>>> b
3.0
>>> b **= a #b = b**a
>>> b
243.0
>>> b //= a #b = b//a
>>> b
48.0
>>>


 

逻辑运算

例子
>>> a  = 15
>>> b = 20
>>> a == 15 and b ==20 #所有条件都满足才会为true
True
>>> a < 20 and b >20
False
>>> a < 20 or b > 20 # 一个条件成立就为true
True
>>> not a< 20    #取反
False

 

成员运算

#例子:
>>> list = [1,2,3,5,6,7]
>>> 1 in list
True
>>> 4 in list
False
>>> 1 not in list
False
>>> 4 not in list
True
>>>

身份运算

#例子:
#如果id(a)等于id(b) 则返回True ,反之返回 False
>>> a = 5
>>> b = a
>>> a is  b
True
# 如果 id(a)不等于id(b)则返回True, 反之返回False
>>> a = 7
>>> a is not b
True
>>>

位运算:

暂时没搞明白,先不写~~~

数据类型

  • 基础数据类型
  • 数据集

基础数据类型

数字

  • 整数
  • 浮点数
  • 复数

整数

整型: 在32位机器上取值范围为 -2* *31 ~ 2 * *31-1 ,64位机器上取值范围为:-2 ** 63 ~ 2 * *63-1

长整型:在Python3中没有整型和长整型之分

浮点数

浮点数:浮点数是属于有理数中特定子集的数字表示,在计算机中用以表示任意某个实数。

 科学计算法:

就是把一个数字以a*10n次幂的方式表现出来。计算机一般把10的几次幂用中的10以e或者E来表示.且a>=1,a<10

 

浮点数的精度问题:

由于在计算机内部整数和浮点数的内存存储方式不同,整数运算永远是精确的,而浮点数运算则会有四舍五入的误差。

Python默认的是17位精度,也就是小数点后16位,但这个精度越往后越不准.

计算高精度的浮点数方法

from decimal import *
getcontext()
getcontext().prec = 20
a = Decimal(1)/Decimal(3)
print(a)

也可以使用字符串格式化的方式来表示:

>>> a =('%.30f'%(1.0/3))
>>> a
'0.333333333333333314829616256247'
>>>

复数

复数是指能写成如下形式的数a+bi,a和b为实数i是虚数。在复数a+bi中,a为复数的实部,b为复数的虚部,i为虚数的单位,当虚部等于0时,这个复数就是实数,当虚部不等0时,这个数就是虚数

#例子
>>> a = (-5+4j)
>>> a
(-5+4j)
>>> type(a)
<class 'complex'>
>>>

其中-5,4为实数,j为虚数.

 

字符串

字符串特性及定义:有序不可修改的字符集合,由一对单,双,三引号包含 包含的内容即字符串

字符串作用:用于存储文本信息

字符串的操作方法:

 1 s = 'hello world'
 2 
 3 s.capitalize()            #返回首字母为大写的字符串
 4 s.casefold()            
 5 s.center()                #以该字符串为中心填充该字符串        参数:长度 ,以什么字符填充(默认空格)
 6 s.count()                #查看该字符串某个字符出现的次数    参数:查看的字符,起始,结束(默认为空)
 7 s.encode()                #以指定编码格式编码字符串            参数:编码(默认UTF-8),设置不同错误的处理方案。默认为 'strict',意为编码错误引起一个UnicodeError. 其他可能得值有 'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 以及通过 codecs.register_error() 注册的任何值。
 8 s.endswith()            #检查字符串是否以 obj 结束.        参数:该参数可以是一个元素或是字符串,起始位置,结束位置
 9 s.expandtabs()            #扩展tab建                        参数:tab键长度(默认:8个空格)
10 s.find()                #坚持字符串中是否包含子字符串str    参数:检索的字符串,起始位置,结束位置
11 s.format()                #字符串格式化                        参数:
12 s.index()                #检测字符串是否包含子字符串str        参数:检索的字符串。起始位置,结束位置
13 s.isalnum()                #如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False
14 s.isalpha()                #如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False
15 s.isdecimal()            #如果字符串中只有十进制字符,返回True,否则返回False
16 s.isdigit()                #如果字符串只包含数字则返回 True 否则返回 False
17 s.isidentifier()        #如果字符串是有效的表示符则返回 True 否则返回False
18 s.islower()                #如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
19 s.isnumeric()            #如果字符串中只包含数字字符,则返回 True,否则返回 False
20 s.isprintable()            #如果该字符串可以打印返回True 否则返回False
21 s.isspace()                #如果如果字符串中只包含空格,则返回 True,否则返回 False.
22 s.istitle()                #如果字符串是标题化的则返回 True,否则返回 False
23 s.isupper()                #如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
24 s.join()                #以指定字符串分割符分割串            参数:要连接的元素序列
25 s.ljust()                #回一个原字符串左对齐,填充至指定长度    参数:长度,以什么填充(默认空格)
26 s.lower()                #将字符串中所有的大写转为小写
27 s.lstrip()                #截掉字符串左边的空格或指定字符。        参数:指定截取的字符(默认空格)
28 s.maketrans()            #创建字符映射转换表                参数:intab:要代替的字符组成的子字符串 outtab:要代替的字符组成的字符串
29 s.partition()            #在字符串中以seq为分隔符,分割字符串    参数:seq 分割方法
30 s.replace()                #将,某个字符替换为另一个字符        参数:旧的字符,新的字符,替换次数(默认全部替换)
31 s.rfind()                #类似find(),区别就是从右边开始查找        参数:查找的字符串,起始位置,结束位置
32 s.rindex()                #类似index(),区别就是从右边开始查找    参数:查找的字符串,起始位置,结束位置
33 s.rjust()                #与ljust()方法相似,区别就是右对齐,填充字符串。        参数:长度,以什么填充(默认空格)
34 s.rpartition()            #在字符串中以seq为分隔符,中字符串右边开始分割字符串        参数:seq 分割符
35 s.rsplit()                #以str为分割符截取字符串,从右边开始截取    参数:分隔符,分割次数
36 s.rstrip()                # 截掉字符串右边的空格或指定字符。 参数:指定截取的字符(默认空格)
37 s.split()                # 以 str 为分隔符截取字符串             参数:分割符 分割次数
38 s.splitlines()            #以按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表   参数:keepends 默认为False 为True则保留换行符
39 s.startwith()            #检测字符串是否已str开头            参数:检索的字符串,可选参数-设置起始位置,可选参数设置结束位置
40 s.strip()                #去除字符串两边的空格                参数:移除指定的序列
41 s.swapcase()            #字符串中的字符大小写互换            
42 s.title()                #将字符串转换成标题格式
43 s.translate()            #以指定表转换字符串的字符(一般与maketrans配合使用) 参数:翻译表,要过滤的字符
44 s.upper()                #将字符串中的小写转换为大写
45 s.zfill()                #返回长度为width的字符串,原字符串右对齐,前面以0填充    参数:长度
46 ###补充
47 len(s)                    #返回字符串的长度

布尔

作用:用来进行逻辑判断

分为真或假(True False)

>>> a =3
>>> b  = 5
>>> a > b
False
>>> a < b
True

数据集

  • 列表
  • 字典
  • 元组
  • 集合

列表

列表的定义:有序的

列表的特性:有序可修改的数据集合

列表的创建

l1 = [1, 2, 3]
# 创建空列表
l2 = []
l3 = list()

列表的操作

C:\Users\67525>python
Python 3.6.6 (v3.6.6:4cf1f54eb7, Jun 27 2018, 03:37:03) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> l = [1,2,3,4,5,6,7,8]
>>> # 访问列表中的值
...
>>> l[1]
2
>>> # 取索引
...
>>> l.index(5)
4
>>> # 切片
...
>>> l[1:5]
[2, 3, 4, 5]
>>> # 添加
...
>>> l.append(8)
>>> l
[1, 2, 3, 4, 5, 6, 7, 8, 8]
>>> l.insert(5,'5')
>>> l
[1, 2, 3, 4, 5, '5', 6, 7, 8, 8]
>>> #修改
...
>>> l[0] = 0
>>> l
[0, 2, 3, 4, 5, '5', 6, 7, 8, 8]
>>> #删除
>>> l.pop()
8
>>> l
[0, 2, 3, 4, 5, '5', 6, 7, 8]
>>> l.remove('5')
>>> l
[0, 2, 3, 4, 5, 6, 7, 8]
>>> l.pop()
8
>>> l
[0, 2, 3, 4, 5, '5', 6, 7, 8]
>>> l.remove('5')
>>> l
[0, 2, 3, 4, 5, 6, 7, 8]

>>> # 循环
>>> for i in l:
...     print(i)
...
0
2
3
4
5
8
>>> # 排序
...
>>> l = ['a','c','B','e','F','d','m','N','@']
>>> l
['a', 'c', 'B', 'e', 'F', 'd', 'm', 'N', '@']
>>> l.sort()
>>> l
['@', 'B', 'F', 'N', 'a', 'c', 'd', 'e', 'm']
>>> # 倒序
...
>>> l.reverse()
>>> l
['m', 'e', 'd', 'c', 'a', 'N', 'F', 'B', '@']
>>>
View Code

 列表的方法详解

l = [1,23,3,4,5,6,7]
l2 =['a','b']
l.append('追加')        #追加一个值  参数:要追加的值
l.copy()             #浅copy
l.count(23)         #查看某个值在该列表中出现的次数  参数: 要查看的值
l.extend(l2)         #拼接列表  参数:要拼接的列表
l.index(3)          #取列表中某个值得索引        参数:要取索引的值,起始位置,结束位置
l.insert(5,'插入')    #插入一个值                参数:要插入的位置,要插入的值
l.pop()                #取列表最后一个值,并删除    参数:可选项,某个值得索引
l.remove()          #删除指定的值            参数:要删除的值
l.reverswe()        #倒序                   
l.sort()            #排序                     #参数 排序方法(默认Ascii码)可选参数 ,是否倒序默认为false
l.clear()            #清空

深浅copy

l1 = [1,2,3,4,5] l2 = l1

该方法 l2则是完全指向了l1的内存地址,所以修改任意列表,其他列表也会跟着受影响。

浅copy:copy一份独立的列表(如果有子列表子列表不独立)。

列表的内存地址是独立的,列表中的值的内存也是独立的. 浅copy,则会给新的列表开辟新的内存地址,列表中的值则会使用原列表的内存地址,如果修改则会像字符串一样在对修改的值开辟一块新的内存地址,因此两个列表之间互相影响。 如果copy的列表中包含子列表(嵌套列表),由于子列表是两个列表共享的,因此子列表并不是有单独的内存地址,,所以修改子列表中的值,两个列表都会受影响。

深copy:copy一份完全独立的列表(包括子列表)

import copy 
l1 = [1,2,3,[4,5]] 
l2 = copy.deepcopy(l1)

字典

字典:一种key-value 的数据类型

字典的特性:key-value结构、key必须可hash且必须为不可变数据类型而且唯一、可存放多个值

可修改、无序、查找速度快

字典的常用操作:

#创建字典
>>> dict={1:2,3:4,5:6,7:9,8:5}
>>> dict
{1: 2, 3: 4, 5: 6, 7: 9, 8: 5}
#添加>>> 
>>> dict['test']=1
>>> dict
{1: 2, 3: 4, 5: 6, 7: 9, 8: 5, 'test': 1}
#修改
>>> dict['test'] = 3
>>> dict
{1: 2, 3 4, 5: 6, 7: 9, 8: 5, 'test': 3}
#查找
>>> dict.get('test')
3
>>> dict['test']        #次方法如果一个key不存在就会报错,而get方法则返回None
3
#循环
>>> for key in dict:
...     print(key,dict[key])
...
1 2
3 4
5 6
7 9
8 5
test 3

字典的方法详解:

dict.clear()        #清空字典
dict.copy()            #浅copy
dict.fromkeys()        #创建一个新的字典,以指定的元素做字典的key,val为字典所有建对应的初始值                    参数:字典键值列表,可选参数 键值序列的初始值
dict.get()            #返回指定key的值,如果值不在字典中返回default值                                         参数:字典的键值         key不存在时返回的值
dict.keys()            #返回列表的所有key
dict.pop()            #删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。     参数:要删除的键值,返回值
dict.popitem()        #随机返回并删除字典中的一对键和值(一般删除末尾对)。如果字典已经为空,却调用了此方法,就报出KeyError异常
dict.setdefault()    #与get()方法类似, 如果键不已经存在于字典中,将会添加键并将值设为默认值                      参数:查找的键值,返回的值
dict.update()        #把字典参数 dict2 的 key/value(键/值) 对更新到字典 dict 里。                            参数:要添加的字典(dict2)
dict.values()        #返回列表里所有的value        

元组

元组的定义:与列表类似,由于不可变的特性被称为只读列表

元组的特性:有序不可变,如果元组中包含其他可变元素,这些可变元素可以改变

元组的使用场景:存放数据库连接配置信息等

元组的操作:

创建:

name=('alex','test','shadan')

其他操作

t = (1,2,3,4,2,5,6)
print(t.index(2,3,5))
print(t.count(2))

# t.index方法:取索引值  参数:要取索引的元组参数 , 从哪里开始 , 到哪里结束
# t.count方法:查看某个参数在该元组中的个数  参数:取值对象
#切片
t1 = t[2::2]
print(t1)

 

集合

集合的作用:去重,测试两组数据之间的交集、差集、并集等关系。

集合的特点:无序且不重复的数据集合确定性(元素必须可hash)

集合的操作:

 1 #集合的创建
 2 >>> set = {1,2,3,4,5}
 3 >>> set2 ={2,3,5,7,8}
 4 #添加
 5 >>> set.add(9)
 6 >>> set
 7 {1, 2, 3, 4, 5, 9}
 8 >>> set.update([8,5,0])
 9 >>> set
10 {0, 1, 2, 3, 4, 5, 8, 9}
11 #删除
12 >>> set.discard(8)
13 >>> set
14 {0, 1, 2, 3, 4, 5, 9}
15 >>> set.pop()
16 0
17 >>> set
18 {1, 2, 3, 4, 5, 9}
19 >>> set = {1,4,7,2,5,8,}
20 >>> set
21 {1, 2, 4, 5, 7, 8}
22 >>> set.remove(4)
23 >>> set

集合的关系测试:

 

#取交集
>>> set.intersection(set2)
{2, 3, 5}
>>> set&set2
{2, 3, 5}
#取差集
>>> set.difference(set2)
{1, 4, 9}
>>> set-set2
{1, 4, 9}
#取并集
>>> set.union(set2)
{1, 2, 3, 4, 5, 7, 8, 9}
>>> set | set2
{1, 2, 3, 4, 5, 7, 8, 9}
#取对称差集
>>> set.symmetric_difference(set2)
{1, 4, 7, 8, 9}
>>> set^set2
{1, 4, 7, 8, 9}

 

 

集合的方法详解:

set = {1,2,3,4,5}
set.add()        #添加一个值到该集合        参数:添加的元素
set.clear()        #清空该集合
set.copy()        #拷贝一个集合
set.difference()    #取差集                参数:要取差集的集合
set.difference_update()        #方法用于移除两个集合中都存在的元素。             参数:用于计算差集的集合
set.discard()    #删除指定的集合元素,如果该元素更不存不会报错        参数:要删除的元素
set.intersection() #取交集                参数:要取交集的集合,其他要取交集的集合(可选参数)多个用逗号隔开
set.intersection_update()    #方法用于移除两个或更多集合中都不重叠的元素。    参数:要查找相同元素的集合,其他要查找相同元素的集合(可选项多个用逗号分隔)
set.isdisjoint()    #判断两个集合是否包含相同元素        参数:要比较的集合
set.issubset()        #判断另一个集合是是否包含次集合    参数
set.issuperset()    #判断集合的所有元素是否都包含在指定集合中。    参数:要查找的集合
set.pop()            #随机删除一个元素
set.remove()        #删除一个指定的元素,如果该元素不存在则报错                参数:要删除的元素
set.symmetric_diffetrence()                #返回两个集合中不重复的元素集合    参数:要计算的集合
set.symmetric_diffetrence_update()        #移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中        #参数:要判断的集合
set.union()            #取并集                参数:要取并集的集合,可选多个集合用逗号分隔
set.update()        #给集合添加元素        参数:添加的元素,可以是集合

 

 

控制流程

分支:判断在特定的条件下执行特定的事件

  • 单分支
  • 双分支
  • 多分支
  • 空语句(pass)

单分支

#语法:
if 条件:
    要执行的事件

双分支:

#语法:
if 条件:
    要执行的事件
else:
    要执行的事件

多分支:

if 条件:
  要执行的事件
elif 条件:
  要执行的事件
elif 条件:
  要执行的事件 ...
else:
  要执行的事件

空语句:

pass

作用:为了保持程序的完整性,pass不做任何事情,一般用作占位语句.

#语法
if
条件: pass else: 要执行的事件

 

循环:重复执行某些特定事件

  • while循环 
  • 死循环
  • while else
  • for循环

while循环:

# 语法
while 条件:
    要执行的事物

死循环dead loop:

 

# 语法
while
条件用于为真: 要执行的事物

while else:

作用:判断循环是否被终止,在while条件为False的情况下执行else语句

while 条件:
    要执行的事物
else:
    要执行的事物

 

for循环

for i in range(10):
    print(i)

i 为临时变量 range 可替换为列表或字典等..

for循环与while循环的区别:while循环可以是死循环而for循环不可以

循环终止语句

 

  • break
  • continue

break:完全终止循环,跳出循环体,执行循环体后面的语句

while 条件:
    if 条件:
        break
     else:
        要执行的事物

continue:终止本次循环,执行后面的语句

while 条件:
    if 条件:
        continue
    else:
        要执行的事物

进制与字符编码

进制

  • 二进制
  • 八进制
  • 十进制
  • 十六进制

 二进制:

二进制的定义:由于计算机只能识别0和1,所以0和1组成的二进制码就是二进制数,最大可表现的10进制数为

2**位数-1

二进制的表现方式:01

二进制与十进制之间的运算:

填位法:

把165转换为二机制

128    64    32    16    8    4    2    1
1    0    1    0    0    1    1    0

 

 

python自带的方法

#参数:要转换的数字
#例子
>>> bin(155)
'0b10011011'
>>>

八进制

表现方式:12345678

八进制与十进制之间的运算

>>> oct(55)
'0o67'
>>>

十六进制

表现方式:0123456789ABCDEF

为什么用16进制:十六进制相对二进制来说更容易表达一个命令或数。

十六进制与二进制之间的运算

取四合一法:https://jingyan.baidu.com/article/47a29f24292608c0142399cb.html

python自带的方法

#python自带的转换方法
>>> hex(99)
'0x63'
>>>

 

字符编码

二进制与文字之间的关系:由于计算机只能识别二进制码,因此要识别文字需要特定的方法吧文字转换为二进制

ASCII:(American Standard Code for Information lnterchange)美国标准信息转换码

ASCll码的作用:把文字转换为十进制数

文字与二级制之间的转换:

通过Ascll码 把 *Xuange*转换为二进制
#十进制
42 88 117 91 110 103 101 42
#二进制
* 00101010
X 01011000
u 01110101
a 01011011
n 01101110
g 01100111
e 01100101
* 00101010

计算机如何区分字符间的二级制码?

由于Ascll码中最大的二级制数是255,而255转换为二级制最多占8位,所以表示每一个字符ASCII码表对应关系的二进制数表示,不够则以为0填充。

计算机种的存储单位:

在二进制中每一个0或1所占的空间都为1bit,8bit等于1个字节(bytes),字节是计算机中最小的容量单位.

容量单位间的转换:

8bit = 1B(bytes) bytes:字节

1024B = 1KB

1024KB = 1MB

1024MB = 1GB

1024GB = 1TB

1024TB = 1PB

字符编码的发展:

由于Ascii码不支持中文,所以要想使计算机识别中文就得另行僻径。

GB2312:又称国标码,由国家标准局发布。1981年5月1日实施,共收录汉字6736个。

GBK1.0:1995年发布GBK1.0,gbk编码能够同时表示简体和繁体字,该编码标准兼容GB2312,共收录汉字21003个,同时包含中日韩文中所有的汉字。

GB18030:2000年发布,是对GBK编码的扩充,覆盖中文,日文,朝鲜语和中国少数名族文字,其中共收录27484个汉字。同时兼容GBK和GB2312编码

BIG5编码:1984年发布,台湾地区使用

为了解决各个国家编码不互通的问题,ISO标准组织拟订了UniCode编码。

Unicode编码:国际标准字符集,它将世界各种语言的没个字符定义唯一编码,以满足跨语言、跨平台的文本信息转换。Unicode(统一码,万国码)规定每个字符和符号最少由16位来表示(2个字节),即:2**16 =65536

UTF-8,是对uincode编码的压缩和优化,它不使用最少2个字节,而是将所有的字符和符号分类:ASCII码中的内容用1个字节保存,欧洲的字符用2个字节保存。东亚的字符用3个字符保存

在Python中使用字符编码

在python2.*中,默认的字符编码是Ascll码。

因为默认不支持中文,所以在python2中想要使用中文需要指定字符便码.

报错:

lucifer@lucifer-VirtualBox:~$ python hello.py 
  File "hello.py", line 2
SyntaxError: Non-ASCII character '\xe4' in file hello.py on line 2, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

解决:在头文件指定字符编码

#! -*- coding:utf-8 -*-
#coding=utf-8

结果:

#指定字符编码后
lucifer@lucifer-VirtualBox:~$ python hello.py
你好 世界!

在python3中默认的字符编码为utf-8,所以不需要考虑编码的问题。

Windows中文版默认编码:GBK

Mac oS/ Linux 默认编码:UTF-8

编码的一些补充

utf是UNincode编码设计的一种在存储和传输时节省空间的编码方案.

字符编码的存储问题:以某种编码存储,必须以存储的编码方式打开

在代码执行的过程中,python3会自动的把代码内容变成Unicode类型。而python2不会自动转换,所以需要把内容重新解码才可以正常显示。

由于Windows中的默认编码是GBK,而python2解释器的默认编码为ASCII,由于python2并不会把文件内容变成Unicode。所以我们要手动的把内容变成Unicode。

UTF-8 --> decode 解码 --> Unicode
Unicode --> encode 编码 --> GBK / UTF-8 ..

bytes类型与Unicode类型

bytes类型与Unicode类型是python2中独立的类型,在python2中Unicode就是把字符串解码后的类型,而bytes,字符串的二进制表现形式.

 

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:python中包的语法

下一篇:python-元组方法(tulpe)知识整理