STCX

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

背景


 

PHP的$和->让人输入的手疼(PHP确实非常简洁和强大,适合WEB编程),Ruby的#、@、@@也好不到哪里(OO人员最该学习的一门语言)。

 

Python应该是写起来最舒服的动态语言了,一下是一些读书笔记,最后会介绍一下高级的用法:Mixin、Open Class、Meta Programming和AOP。

 

文中有些地方是用2.7开发的,如果您安装的是3.x,有几点需要注意:

 

  •     print "xxx" 要换成 print("xxx")

  •     __metaclass__ = type 删除掉。

 

类型和表达式部分


 

你好,世界!

 

1 # coding=utf-8

2

3 print "你好,世界。"

 

 乘方

 

1 print 2**10

 

变量

 

1 var = 1

2 print var

3

4 var  = "段光伟"

5 print var

 

注:这里的var = xxxx不叫变量赋值,而叫变量绑定,python维护了一个符号表(变量名)以及符合对应的值,这个对应关系就叫做绑定,一个符号可以绑定任意类型的值。

 

获取用户输入

 

1 #获取用户输入

2 x = input("x:")

3 y = input("y:")

4

5 print x*y

  

 

注:input接受的是Python代码,输入中可以访问当前执行环境中的变量,如果想获取原始输入需要使用 raw_input。


函数定义

 

1 def say_b():

2  print "b"

 

强类型

 

Javascript和Php是弱类型的,Python和Ruby是强类型的。弱类型允许不安全的类型转换,强类型则不允许。

 

1 #1 + “1” 这行代码在Python中会报错。

2 print 1 + int("1")

3 print str(1) + "1"

 

 字符串

 

#字符串
print ''''    段
            光
            伟'''
print r'C:\log.txt'
print 'C:\\log.txt'

 

序列

 

这里先介绍三种序列:列表、元祖和字符串。

序列通用操作

 

seq = "0123456789"
print seq[0] #从0开始编码。
print seq[-1] #支持倒着数数,-1代表倒数第一。
print seq[1:5] #支持分片操作,seq[start:end],start会包含在结果中,end不会包含在结果中。
print seq[7:] #seq[start:end]中的end可以省略。
print seq[-3:] #分片也支持负数。
print seq[:3] #seq[start:end]中的start也可以省略。
print seq[:] #全部省略会复制整个序列。
print seq[::2] #支持步长。
print seq[::-2] #支持负步长。
print seq[9:1:-1] #支持负步长。
print [1, 2, 3] + [4, 5, 6] # 序列支持相加,这解释了为啥字符串可以相加。
print [1, 2, 3] * 3 #序列支持相乘,这解释了为啥字符串可以相称。
print [None] * 10 #生成一个空序列。
print 1 in [1, 2, 3] #成员判断。

 

 可变的列表

 

data = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];

data[0] = "a" #修改元素。
print data
data[0] = 0

del data[10] #删除元素。
print data

del data[8:] #分片删除。
print data

data[8:] = [8, 910] #分片赋值
print data

 

不可变的元祖

 

 

1 print (1, 2) #元祖以小括号形式声明。

2 print (1,) #一个元素的元祖。

 

 

字符串格式化

 

print "% 10s" % "----"

print '''
%(title)s
%(body)s
''' % {"title": "标题", "body": "内容"}

 

字典

 

1 print {"title": "title", "body": "body"}

2 print dict(title = "title", body = "body")

3 print dict([("title", "title"), ("body", "body")])

 

1 dic = {"title": "title", "body": "body"};

2 print dic["title"]

3 del dic["title"]

4 print dic

 

print 语句

 

1 print 'a', 'b' #print可以接受多个参数,参数的输出之间以空格相隔。

2 print 'a', #如果逗号之后没有参数,则不会换行。

3 print 'b'

 

序列解包

 

x, y, z = 1, 2, 3
print x, y, z
(x, y, z) = (1, 2, 3)
print x, y, z
(x, y, z) = [1, 2, 3]
print x, y, z

 

bool值

 

#下面的输入全部返回False。
print(bool(None))
print(bool(()))
print(bool([]))
print(bool({}))
print(bool(""))
print(bool(0))

#虽然这些值在条件运算中会当做False,但是本身不等于False。
print(True and "")
print(not "")
print(False == "")
print(False == 0) #0除外,bool类型的内部表示就是int类型。

 

语句块

 

:开始语句快,缩进的所有内容都是一个语句块。

 

1 if(10 > 1):

2     print("10 > 1")

3 else:

4     print("不可能发生")

 

三元运算符

 

1 print("10 > 1" if 10 > 1 else "不可能发生")

 

相等比较

 

#== 和 is的差别,==比较的是内容,is比较的是引用。
x = [1, 2, 3]
y = x
z = [1, 2, 3]
print(x == y)
print(x == z)
print(x is y)
print(x is z)

 

循环

 

#for循环类似C#的foreach,注意for后面是没有括号的,python真是能简洁就尽量简洁。
for x in range(1, 10):
    print(x)

for key in {"x":"xxx"}:
    print(key)

for key, value in {"x":"xxx"}.items():
    print(key, value)

for x, y, z in [["a", 1, "A"],["b", 2, "B"]]:
    print(x, y, z)

 

#带索引的遍历
for index, value in enumerate(range(0, 10)):
    print(index, value)

#好用的zip方法
for x, y in zip(range(1, 10), range(1, 10)):
    print(x, y)

#循环中的的else子句
from math import sqrt
for item in range(99, 1, -1):
    root = sqrt(item)
    if(root == int(root)):
        print(item)
        break
else:
    print("没有执行break语句。")

 

pass、exec和eval

 

#pass、exec、eval
if(1 == 1):
    pass

exec('print(x)', {"x": "abc"})
print(eval('x*2', {"x": 5}))

 

函数部分


 

形参和实参之间是按值传递的,当然有些类型的值是引用(对象、列表和字典等)。

 

# 基本函数定义。
def func():
    print("func")

func()

# 带返回值的函数。
def func_with_return():
    return ("func_with_return")

print(func_with_return())

# 带多个返回值的函数。
def func_with_muti_return():
    return ("func_with_muti_return", "func_with_muti_return")

print(func_with_muti_return())

# 位置参数
def func_with_parameters(x, y):
    print(x, y)

func_with_parameters(1, 2)

# 收集多余的位置参数
def func_with_collection_rest_parameters(x, y, *rest):
    print(x, y)
    print(rest)

func_with_collection_rest_parameters(1, 2, 3, 4, 5)

#命名参数
def func_with_named_parameters(x, y, z):
    print(x, y, z)

func_with_named_parameters(z = 1, y = 2, x = 3)

#默认值参数
def func_with_default_value_parameters(x, y, z = 3):
    print(x, y, z)

func_with_default_value_parameters(y = 2, x = 1)

#收集命名参数
def func_with_collection_rest_naned_parameters(*args, **named_agrs):
    print(args)
    print(named_agrs)

func_with_collection_rest_naned_parameters(1, 2, 3, x = 4, y = 5, z = 6)

#集合扁平化
func_with_collection_rest_naned_parameters([1, 2, 3], {"x": 4, "y": 4, "z": 6}) #这会导致args[0]指向第一个实参,args[1]指向第二个实参。
func_with_collection_rest_naned_parameters(*[1, 2, 3], **{"x": 4, "y": 4, "z": 6}) #这里的执行相当于func_with_collection_rest_naned_parameters(1, 2, 3, x = 4, y = 5, z = 6)。

 

作用域


 

# coding=utf-8

# 只有函数执行才会开启一个作用域。
if(2 > 1):
    x = 1

print(x) # 会输出1。

# 使用vars()函数可以访问当前作用域包含的变量。
x = 1
print(vars()["x"])

# 使用globals()函数可以访问全局作用域。
x = 1

def func():
    print(globals()["x"])

func()

# 使用locals()函数可以访问局部作用域。
def func():
    x = 2
    print(locals()["x"])
func()

# 每个函数定义时都会记住所在的作用域。
# 函数执行的时候会开启一个新的作用域,函数内变量访问的规则是:先访问当前作用域,如果没有就访问函数定义时的作用域,递归直到全局作用域。
x = 1

def func():
    y = 2
    print(x, y) # 输出1 2

func()

# 变量赋值始终访问的是当前作用域。
x = 1

def func():
    x = 2
    y = 2
    print(x, y) # 输出2 2

func()
print(x) #输出 1

# 局部变量会覆盖隐藏全局变量,想访问全局变量可以采用global关键字或globals()函数。
x = 1

def func():
    global x
    x = 2
    y = 2
    print(x, y) # 输出2 2

func()
print(x) #输出 2

 

 


# python支持闭包
def func(x):
    def inner_func(y):
        print(x + y)

    return inner_func

inner_func = func(10)
inner_func(1)
inner_func(2)

 


#函数作为对象
def func(fn, arg):
    fn(arg)

func(print, "hello")
func(lambda arg : print(arg), "hello")

 

模块


 

几个模块相关的规则:

  • 一个文件代表一个模块。

  •  可以用import module导入模块,也可以用form module import member导入模块的成员。

  • 如果导入的是module,必须使用module.member进行访问;如果导入的member,可以直接访问member。

  • 导入的module或member都会变成当前module的member。

 

b.py

# coding=utf-8
print __name__

def say_b():
    print "b"

 

 

a.py

 

# coding=utf-8

import b
from b import *

print __name__

def say_a():
    print "a"

 

test.py

 

# coding=utf-8

import a

print __name__

a.say_a();
a.say_b();
a.b.say_b()

 

输出

 

b
a
__main__
a
b
b

 

出自:博客园

原创作者:幸福框架

 

原链接:http://mp.weixin.qq.com/s?__biz=MjM5MTYxNjQxOA==&mid=2652841225&idx=1&sn=7f942129e2a288e0094369dbe19b2a01&chksm=bd5959c48a2ed0d266839037ab615b19c2778126e7da2254f117ba3f42728773096c649d3602&mpshare=1&scene=23&srcid=03278Xbr1eyFKYcEkfu5HZvo#rd

posted on 2018-03-27 19:26  STCX  阅读(101)  评论(0)    收藏  举报