编程语言
用户:
问题空间
计算机:解决问题
解空间
抽象
机器代码->微码编码->高级语言

shell编程
控制语言:胶水语言
框架:web,Django
字节码:bytecode

面向过程:
以指令为中心,由指令处理数据
如何组织代码解决问题
面向对象:
以数据为中心,所有的处理代码都围绕数据展开
如何让设计数据结构组织数据,并提供对此类数据所允许处理操作

简单方法:
1.编译安装新版本至某特定路径
2.pyenv

数据类型:转换
隐式
显式

字典:kv集合
{'a':31,'b':71}

Python过程式编程:

每个模块都有一个人名为name的内建变量,此变量值会根据调用此模块的方式发生变化
如果此文件被作为模块导入,则name的值为模块名称
如果此文件被直接执行,则name的值为"main"

class:自定义类型
type:

instance:实例化

类:数据和方法
数据:变量
方法:函数

类:实例化成对象
CA:
IA:
IB:

两个对象比较:
1。值比较:对象中的数据是否相同
2.身份比较:两个变量名引用的是否为同一对象

核心数据类型:
数字:int,long,float,complex,bool
字符:str,unicode
列表:list
字典:dict
元组:tuple
文件:file
其他类型:集合(set),frozenset,类类型,None

其他文件类工具:pipes,fifos,sockets

类型转换:
str(),repr()或format(): 将非字符型数据转换为字符:
int():转为整数
float():

list(s)将字符串 s转为列表
tuple(s):将字符串s转为元组
set(s):将字符串s转为集合
frozenset(s):将字符串s转换为不可变集合
dict(d):创建字典:其d必须是(key,value)的元组序列

chr(x):将整数转为字符
ord(x):将字符转换为整数值
hex(x):将整数转换为16进制字符
bin(x):
oct(x):

数字类型:

Python的数字字面量:布尔型,整数,浮点数,复数
True:1
False:0

序列类型:
字符类型:
字符串字面量:把文本放入单引号,双引号或三引号中;
''',"""

如果要使用unicode编码,则在字符串之前使用字符u进行标识,如u"magedu"
文档字串:模块,类或函数的第一条语句是一个字符的话,该字符串就成为文档字符串,可以使用doc属性引用

运算符:
索引运算:[i]
切片运算:[i:j]
扩展切片:[i:j:stride]

支持运算:
索引,切片,main(),max(),len()等
支持操作:
对象的自由的方法

列表:
容器类型
任意对象的有序集合,通过索引访问其中的元素,可变对象,异构,任意嵌套

支持在原处修改
修改指定的索引元素,修改指定的分片,删除语句,内置方法

l1+l2:合并两个列表,返回一个新的裂变,不会修改原列表
l1 * N:把l1重复N次,返回一个新列表;

 in:成员关系判断字符,用法objin container
 not in:obj not in container

列表解析:[ ]
列表复制方式:
l1=[1,2,3,4]
l2=l1

   import copy
     l2=copy.deepcopy(l1)

        l2=l1[:]

元组:
表达式符号:()

容器类型
任意对象的有序集合,通过索引访问其中的元素,不可变对象,长度固定,异构,嵌套
常见操作:
()
(1,)
(1,2,)

 t1+t2
 t1*N

  in:
  not in:

虽然元组本身不可变,但如果元组内嵌套了可变类型的元素,那么此类元素的修改不会返回新元组

字典:dict
字典在其他编程语言中又称作关联数组或散列表;
通过键实现元素存取,无序集合;可变类型容器,长度可变,异构,嵌套;

{key1:value1,key2:value2,...}
{}:空字典
{'x':32,'y':[1,2,3]}

字典复制:d2 d1.copy()
d1.iteritems:返回一个迭代器对象

回顾:
python:动态语言,强类型
内置类型,自定义类型(class)
整数,布尔
浮点

    序列
        字符集,列表,元组
    字典:
       集合:set,frozenset

    可变对象:列表,字典,set
    不可变对象:数值,字串,元组,frozenset

对象的三部分:身份,类型,值
对象的比较:
身份比较:用于确定是否同一个对像
id()
类型比较:用于确定是否同属于一个类型
type()
值比较:值是否相同
直接等值比较

数值,字串,列表,元组,字典

类:数据+方法
实例:

3+5
3.add(5)

列表和字典:

变量名
对象

点号运算符:
属性:数据
返回一个数据,显示则要使用print语句
方法:操作()
调用:执行一段代码

可调用对象:callable()

字串:'',"",''' ''',""" """,
列表:[ ]
元组:()
字典:{}
数值:

如何获取使用帮助:
获取对象支持使用的属性和方法:dir()
某方法的具体使用帮助:help(list.pop)
获取可调用对象的文档字串:print objdoc

集合:无序排列,可哈希;
支持集合关系测试:
成员关系测试:
in
not in
迭代
不支持:索引,元素获取,切片

集合的类型:set(),frozenset()
没有特定语法格式,只能通过工厂函数创建

容器,类型,对象
1.列表,字典可以不使用换行符
2.所有对象都有引用计数
3.列表和字典都支持两种类型的复制操作,浅复制和深复制;深复制可使用copy模块中的deepcopy()实现
4.python中的所有对象都是“第一类的”,这意味着使用标识符命名的所有对象都具有相同状态,于是,能够命名所有对象都可以直接当数据进行处理
5.所有序列都支持迭代;
6.所有序列都支持的操作和方法:
s[i]
s[i:j]
s[i:j:stride]
len(s)
min(s)
max(s)
sum(s)
all(s)
any(s)
s1+s2:连接
s1*N:重复
obj in s1:成员关系判断
obj not in s1:
7.可变序列的操作:
s1[index]=value:元素赋值
s1[i:j]=t:切片赋值
del s1[index]
del s1[i:j]
del s1[i:j:stride]

Pyhon的表达式和语句:

表达式:
语句:

Python中的常用的表达式操作符;
x * y,x/y,x+y,x-y,x//y,x%y

逻辑运算:
x or y,x and y,not x
成员关系运算:
x in y,x not in y
对象实例测试:
x is y,x not is y
比较运算:
x y,xy,x y,x ! y
位运算:
x | y,x & y,x ^y,x <>y

一元运算:
-x,+x,~x:
幂运算:
x ** y

索引和分片:
x[i],x[i:j],x[i:j:stride]

调用:
x(...)

取属性:
x.attribute

元组:(...)
序列:[...]
字典:{...}

三元选择表达式:x if y else z

匿名函数:lambda args:expression

生成器函数发送协议:yield x

运算优先级:
(...),[...],{...}
s[i],s[i:j]
s.attribute
s(...)
+x,-x,~x
x * y
,/,//,%
+,-
<<,>>
&
^
|
<.<=,>,>=,==,!=
is,not is
in,not in
not
and
or
lambda

语句:
赋值语句
调用
print:打印对象
if/elif/else:条件判断
for/else:序列迭代
while/else:普通循环
pass:占位符
break:
continue
def
return
yield
global:命名空间
raise:触发异常
import:
from:模块属性访问
class:类
try/except/finally:捕捉异常
del:删除引用
assert:调试检查
with/as:环境管理器

赋值语句:
隐式赋值:import,from,def,class,for,函数参数

元组和列表分解赋值:当赋值符号(=)的左侧为元组或列表时,python会按照位置把右边的对象和左边的目标自左而右逐一进行配对儿,个数不同时会触发异常,此时可以切片的方式进行;

多重目标赋值

增强赋值语句:+,-,*,/,//,%,

条件测试:
if 条件测试表达式

Python中的真假
1.任何非0数字和非空对象都为真
2.数字0,空对象和特殊对像None均为假
3.比较和像等测试会递归地应用于数据结构中
4.返回值为Ture或False

组合条件测试:
X and Y:与运算
X or Y:或运算
not X:非运算

A=X if Y else Z:
if Y:
A=X
else
A=Z
expression1 if boolean_expression else expression2

while:

while bool_expression:
while_suite
else:
else_suite
break:跳出最内层的循环
continue:跳到所处的最近层循环的开始处
pass:占位语句
else代码块:循化正常终止才会执行,如果循环终止是由break跳出导致的,则else不会执行

练习1:逐一显示指定列表中的所有元素
count=0
while countprint(l1[count])
count +=1

while l1:
print(l1[0])
l1.pop(0)

while l1:
print(l1[-1])
l1.pop()

练习2:求100以内所有偶数之和

练习3:逐一显示指定字典的所有键;并于显示结束后说明总键数
d1={'x':1,'y':23,'z':78}
keylist=d1.keys()
while keylist:
print(keylist[0])
l1.pop()
else:
print(len(d1))

练习4:创建一个包含了100了以内所有奇数的列表;
l1=[]
x=1
while x<100:
l1.append(x)
x+2

练习5:逆序逐一显示一个列表的所有元素
练习6:列表l1=[0,1,2,3,4,5,6],列表l2=['Sun','Mon','Tue','Wed','Thu','Fri','Sat'],以第一个列表中的元素为键,以第二个列表中的元素为值的生成字典d1
d1={}
count=0
if len(l1)==len(l2):
while countd1[l1[count]]=l2[count]
count+=1

while True:

for 循环练习:
练习1:逐一分开显示指定字典d1中的所有元素,类似如下
k1 v1
k2 v2
....
for (k,v) in d1.items():
print(k,v)

练习2:逐一显示列表中l1=['Sun','Mon','Tue','Wed','Thu','Fri','Sat']中的索引为奇数的元素
for i in range(1,len(l1),2):
print(l1[i])

练习3:将属于列表l1=['Sun','Mon','Tue','Wed','Thu','Fri','Sat'],但不属于列表l2=['Sun','Mon','Tue','Thu','Sat']的所有元素定义为一个新列表l3
l3=[]
for i in l1:
if l1[i] not in l2:
l3.append(i)

练习4:已知列表namelist=['stu1','stu2','stu3','stu4','stu5','stu6','stu7'],删除列表removelist=['stu3','stu7','stu9'],请将属于removelist列表中的每个元素从namelist中移除(属于removelist,但不属于namelist的忽略即可)
for i in removelist:
if i in namelist:
namelist.remove(i)

回顾:
1.动态语言
sys.getrefount()

 增加对象的引用计数场景
       对象创建时:
       将对象添加进容器时:类似list.append()
      当对象被当作参数传递给函数时
      为对象创建另外变量名

减少引用计数:
     引用此对象的某变量名被显式销毁:del x
    引用此对象的某变量名重新赋值
    从容器中移出对象时,类似list.pop()
   容器本身被销毁

2.if
if boolean_expression:
.....
elif boolean_expression:
....
else
....
3.while
while boolean_expression:
while_suite
if boolean_expression2: continue
if boolean_expression3: break
else:
else_suite

4.for
for expression in object:
for_suite
if boolean_expression2: continue
if boolean_expression3: break
else:
else_suite

while True:
x=input('enter an entry: ')
test.append(x)
if x=='q' or x=='quit':
break

列表解析:根据已有列表,高效生成新列表的方式
['x','y','z'],[1,2,3]
[('x',1),('x',2)]

var_name=open(file_name[mode,[bufsize]])
mode:
r
w
a
r+
w+
b表示以二进制模式打开文件:
rb
wb
ab
b+
wb+
ab+

缓冲:
0:禁用
负数:使用系统默认缓冲
1:使用缓冲,只缓冲一行数据
2+:指定缓冲空间大小
file.seek(offset[whence])
whence:起点
0:从文件头
1:从当前位置
2:从文件尾部

 offset:偏移量

文件系统功能:os

目录:
chdir():表示改变工作目录
chroot():设定当前进程的根目录
listdir():列出指定目录下的所有文件名
mkdir():创建指定目录
makedirs():创建多级目录
getcwd()
rmdir()
removedirs():删除多级目录

文件:
mkfifo()
mknod()
remove()
unlink()
rename():重命名
stat():返回文件状态信息
symlink()
utime():更新时间戳
tmpfile():创建并打开(w+b)一个新的临时文件

访问权限:
access():
chmod():修改权限
chown():修改属主,属组
umask():设置默认权限模式

文件描述符:
open():
read():
write():

设备文件:
mkdev():
major():
minor():

os.path:跟文件路径相关
basename():路径基名
dirname():路径目录名
join():
split():返回dirname(),basename()元组
splitext():返回(filename,extension)元组

信息:
getatime()
getctime()
getmtime()
getsize():返回文件的大小

查询:
exists():判断指定文件是否存在
isabs():判断指定的路径是否为绝对路径
isdir():是否为目录
isfile():是否为文件
islink():是否符号链接
ismount():是否为挂载点
samefile():两个路径是否指向了同一个文件

练习:判断文件是否存在,存在则打开
让用户通过键盘反复输入多行数据
追加保存至此文件中

对象持久存储:
pickle
marshal

DBM接口:

shelve模块

回顾:
文件对象
open('file','mode','bufsize')
read,readline,readlines,write,writelines,flush,seek,tell

模块:os
文件系统接口
模块:os.path

对象流式化:持久化
pickle

文件是可迭代:iter(),iter()

Python的正则表达式:
.
[...]
[^...]
?
+
{m}
{m,n}
{0,n}
{m,}
^
$
pat1|pat2
(...)
\b
[0-9] \d
[0-9a-zA-Z] \w,\W
\s:任意空白字符,[\n\t\f\v\r], \S
\nn
(*|+|?{})?:使用非贪婪模式

match对象:

re.search:返回一个match对象
match对象的:
属性:
string
re
pos
endpos
方法:
group()
start()
end()

re.findall:返回列表
re.sub:返回替换后整个串
re.subn:返回元组,替换后的串及替换次数

re.compile:

思考:复制/etc/passwd到/tmp,如何替换/tmp/passwd中的/BIN/BASH?

flags:
I或IGNORECASE:忽略字符大小写
M或MUTILINE:
A或ASCII:仅执行8位ASCII码匹配
U或UNICODE:使用\w,\W

函数:
名称

python闭包:

def funcName(arg1,arg2,...):

参数传递形式:
位置参数:从左向右
关键字参数:按关键名称匹配

混用上面两种方式时:所有位置参数,所有的关键字参数

定义函数使用默认参数:有默认值的参数
混用有默认和无默认值的参数时,无默认值放前面

调用函数时使用可变参数要求:
定义函数时使用*:收集位置参数
定义函数时使用**:收集关键字参数

练习:返回/etc/passwd中包含了/bin/bash字串的所有用户名为一个列表

回顾:
re
search,findall,finditer,sub,subn

function
()
def func_name(arg1,...):
func_suite

Python闭包:闭包叫lexical closure

函数中使用yield,,会返回一个生成器对象

装饰器:
1.装设计器本身是一个函数,用于装饰其他函数;
2.功能:增强被装饰函数的功能

装饰器一般接受一个函数对象作为参数,以对其进行增强

递归:
递归需要边界条件,递归前进段和递归返回段;

协程:

函数的设计规范:
耦合性:
(1)通过参数接受输入,以及通过return产生输出以保证函数的独立性
(2)尽量减少使用全局变量进行函数间通信
(3)不要在函数中修改可变类型的参数
(4)避免直接改变定义在另外一个模块中的变量;
聚合性:
(1)每个函数都应该有一个单一的,统一的目标
(2)每个函数的功能都应该相对简单

练习1:将/etc/passwd文件中的每一行都分隔为一个列表
练习2:将任意文件被用户指定的分隔符把每一行都分隔为一个列表
练习3:用折叠的方式(return)求阶乘

类:将同一种具体物事的共同特性抽象出来的表现
状态和转换这些状态的操作
数据:
变量:就属性
方法:
函数:操作变量引用的数据的代码

面向对象编程的3原则:
封装,继承和多态

class class_name

class thirdclass():
data='hello third'
def setdata(self,x):
self.str1=x
def printdata(self):
print(self.str1)

ins4=thirdclass()
ins4.setdata('abcd')<--->thirdclass.setdata(ins4,'abcd')
ins4.printdata()<-->thirdclass.printdata(print(ins4.str1))
abcd

varname():会被Python解释器自动调用
a+b<-->a.add(b)
l1=['abcd','xyz']<-->list.init()

可调用对象:call()
函数
内置函数
自定义函数
def
lamdba

类方法

函数的属性:
doc
name
dict
code
globals

方法的属性:
doc
name
class:方法所属的类
func:实现该方法的函数对象
self:调用此方法的实例

内置函数:
doc
name
self

类:
doc
name
bases
dict
module:定义了当前类的模块名称

实例:
class
dict

对象都有特殊方法:
init,new,del
dir()
add()
ge()

模块:
顶层文件
模块文件1
模块文件2

setup.py中setup()中可用的参数:
platforms:平台列表
license:许可证
py_modules:各模块名称组成的列表,此些模块可能位于包的根目录下,也可能位于某子包目录下(subpkg1.modename):
packages:各子包名称的列表

大体分为两类:元数据信息和包中的内容列表

python setup.py sdist
可以指定格式:
zip:zip file
gztar:tar.gz file
bztar:tar.bz2 file
ztar:tar.Z file
tar:tar file

python setup.py bdist

可以为bdist指定的格式: --formats
gztar:tar.gz file
ztar:tar.Z file
tar:tar file
zip:zip file
pkgtool:Solaris pkgtoo1
wininst:Windows上自解压的zip格式的包
msi:Microsoft Installer

bdist_dump:
bdist_rpm:
bdist_wininst
dbsit_msi

获取帮助的方式:
python setup.py --help
python setup.py --help--commands:所有可以使用的命令,如build,install
python setup.py COMMAND --help:获取将特定命令的帮助
python setup.py COMMAND --help-formats:获取特定命令支持使用的格式

pip,easy_install

Python模块,包,打包

安装包:
python setup.py install

build and install:

python setup build:
--build-base /path/to/build_dir
lib,lib.platform
第三方模块的默认安装路径通常为:site-packages
/usr/local/python27/lib/python2.7/site-packages

自定义安装路径:
--user

--prefix
--exec-prefix

深度定制:
--install-purelib /path/to/python_lib
--install-platlib /path/to/plat_lib
--install-lib /path/to/lib

--install-scripts /path/to/bin
可执行文件的安装路径

--install-data
--install-headers

try:
try:
try_suite
except
except
else
finally

assert实现:手动触发异常
assert condition,[expresson]
相当于下面的语句
if debug:
if not condition:
raise AssertionError,expression

Python异常对象:
BaseException:

raise触发异常

assert断言

try-except
try:
except
except()
except BaseException
else

try-finally
try-except-else-finally

try:
try-except-else
finally:

execute()
executemany()

import pymysql as mysql
建立连接:
conn=mysql.connect('host','user','password','db')
创建游戏标:
cur=conn.cursor()
发送查询:
sqlstatement='sql statement'
cur.execut(sqlstatement)
cur.executemany(sqlstatement)

获取数据:
cur.execute('select statement')
cur.fetchone()
cur.fetchmany(N)
cur.fetchall()

fetchall():
result=cur.fetchall()
关闭:
cur.close()
conn.close()

练习:把/etc/passwd文件中的内容的每一行存储在mariadb的表中;

socket.socket(family,type)

family:
AF_INET:
AF_UNIX:
type:
STREAM:tcp
SOCK_DGRAM:udp

tcponn=socket.socket(socket.AF_INET,socket.SOCK_STREAM)

第二步:绑定地址
使用套接字对象的bind方法绑定于某地和端口
tcpconn.bind(('ip',port))
tcpconn.bind(('127.0.0.1',8023))

第三步:使用listen方法进行监听状态
tcpconn.listen(backlog)
tcpconn.listen(100)

第四步:循环监听状态
使用套接字对象的accecpt方法接收用户请求

编写客户端程序:
第一步:创建一个socket对象,以连接服务器端
cliensock=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
第二步:连接至服务器
clientsock.connect(('server_ip',server_port))
clientsock.connect(('127.0.0.1',8023))

第三步:发送请求:
clientsock.send()

服务器端:
import socket
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sa=('127.0.0.1',8023)
s.bind(sa)
s.listen(20)
while True:
cinfo,cpaddr=s.accept()
print('Got a connection from %s'%caddr[0])
data=cinfo.recv(1024)
print('Eeceive data:%s'%data)
cinfo.send("echo: "+data)
cinfo.close()

客户端:
import socket
c=socket.socker(socket.AF_INET,socket.SOCK_STREAM)
saddr=('127.0.0.1',8023)
c.connect(saddr)
c.send('hello server')
data=c.recv(1024)
print("Reply from server %s"%data)

web框架:
Diango
Flask
Web2py
TuborGears
TuborGears