数字相关函数
1、绝对值:abs(-1)
2、最大最小值:max([1,2,3])、min([1,2,3]),对序列进行操作
3、序列长度:len(‘abc’)、len([1,2,3])、len((1,2,3))
4、取模:divmod(5,2)//(2,1)得到一个元组
5、乘方:pow(2,3,4)//2**3/4
6、浮点数:round(3.1415926,2)//3.14 四舍五入

#取绝对值
print abs(-1)  

#最大最小值
list1 = [1,3,5]
print 'max is :%d'%max(list1)
print 'min is :%d'%min(list1)

#长度
print len(list1)

# help()查看函数帮助文档
help(divmod)
print divmod(5,2)

help(pow)
print pow(2,3) #2**3/2的3次方/8
print pow(2,3,4) #2**3%4/0

help(round)
print round(3.1415926,2) #保留几位小数

功能相关函数
1、函数是否可调用:callable(funcname),注意,funcname变量要定义过
2、类型判断:isinstance(x,list/int)
3、比较:cmp(‘hello’,’hello’)
4、快速生成序列:(x)range([start,] stop[, step])

#1、函数是否可调用:callable(funcname),注意,funcname变量要定义过
callable(num)
#NameError: name 'num' is not defined

#callable 对象是一个变量,返回false
num  = 1
print callable(num)  #False
#http://www.pythontab.com/html/2013/hanshu_0125/169.html

#callable函数对象是divmod,返回Ture,代表函数可以调用
print callable(divmod) #Ture

# 2、类型判断
 list1 = [1,3,5]
print isinstance(list1,list)  #True
print isinstance(list1,tuple)  #False

# 3、cmp(x,y)比较x与y的内容是否相等,
# 相等返回0,x小于y 返回-1,x大于y 返回1
print 'x等于y :%d'%cmp(1,1)  #x等于y :0
print 'x等于y :%d'%cmp('aaa','aaa')  #x等于y :0
print 'x小于y :%d'%cmp(1,2)  #x小于y :-1
print 'x大于y :%d'%cmp(2,1)  #x大于y :1
print cmp([1,2,3],[1,2,4])   #-1

# 4、生成序列,range(),xrange()
list2 =  range(1,11)
print type(list2),list2
#<type 'list'> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

# 5、xrange()不生成list
print type(xrange(1,11)),xrange(1,11) 
#<type 'xrange'> xrange(1, 11)
for i in xrange(1,11):
    print i

数据类型转换函数
1、int(x)
2、long(x)
3、float(x)
4、complex(x) //复数
5、str(x)
6、list(x)
7、tuple(x) //元组
8、hex(x)
9、oct(x)
10、chr(x)//返回x对应的字符,如chr(65)返回‘A’
11、ord(x)//返回字符对应的ASC码数字编号,如ord(‘A’)返回65

str1 = '123'
print type(int(str1)),int(str1)
print type(long(str1)),long(str1)
print type(float(str1)),float(str1)
print type(complex(str1)),complex(str1)

int1 = 123
print type(str(int1)),str(int1)
print type(list(str1)),list(str1)
print type(tuple(str1)),tuple(str1)

# 数字不同进制的转换
print type(hex(int1)),hex(int1)
print type(oct(int1)),oct(int1)

# 返回ASCII码对应的字符
print chr(65)
print chr(97)

# 返回字符对应的ASCII码
print ord('A')
print ord('0')

字符串处理
1、首字母大写:str.capitalize()
2、字符串替换:str.replace()
3、字符串切割:str.split()

nameStr = 'xiaoming'
print nameStr.capitalize()   #Xiaoming

help(nameStr.replace)
#S.replace(old, new[, count]) -> string

print nameStr.replace('m','l') #xiaoling
print nameStr.replace('ming','hong') #xiaohong
print nameStr.replace('i','x') #xxaomxng
print nameStr.replace('i','x',1) #xxaoming

help(nameStr.split)
# S.split([sep [,maxsplit]]) -> list of strings

ip = '192.168.2.1'
print ip.split('.')  #['192', '168', '2', '1']
print ip.split('.',2)  #['192', '168', '2.1']

序列处理函数
1、len()序列长度
2、max()序列中最大值
3、min()最小值
4、filter()过滤序列
5、zip()并行遍历
6、map()并行遍历,可接受一个function类型的参数
7、reduce()递归

help(filter)
#filter(function or None, sequence) -> list, tuple, or string

def is_even(x):
    if x%2==0:
        return True
print filter(is_even,range(1,11)) . #[2, 4, 6, 8, 10]
print filter(lambda x:x%2==0,range(1,11))#[2, 4, 6, 8, 10]

# zip(),并行遍历
name=['xiaoming','xiaohong','xiaofang','xiaogang']
age=[19,20,21,22]
city=['Beijing','Shanghai','Shenzhen','Hangzhou']
print zip(name,age,city)
#[('xiaoming', 19, 'Beijing'), ('xiaohong', 20, 'Shanghai'), ('xiaofang', 21, 'Shenzhen'), ('xiaogang', 22, 'Hangzhou')]

# 如何序列的长度不同
name=['xiaoming','xiaohong','xiaofang','xiaogang']
age=[19,20,21]
city=['Beijing','Shanghai','Shenzhen','Hangzhou']
print zip(name,age,city)
#[('xiaoming', 19, 'Beijing'), ('xiaohong', 20, 'Shanghai'), ('xiaofang', 21, 'Shenzhen')]元素冗余的不能匹配的不操作

# map:并行遍历,可接受一个function类型的参数
# map缺少元素补全。
print map(None,name,age,city)
#[('xiaoming', 19, 'Beijing'), ('xiaohong', 20, 'Shanghai'), ('xiaofang', 21, 'Shenzhen'), ('xiaogang', None, 'Hangzhou')]
#缺少元素,默认用None补齐

gender=['male','female']
print map(None,name,age,city)
#[('xiaoming', 19, 'Beijing'), ('xiaohong', 20, 'Shanghai'), ('xiaofang', 21, 'Shenzhen'), ('xiaogang', None, 'Hangzhou')]

a=[1,3,5]
b=[2,4,6]
print map(None,a,b)  #[(1, 2), (3, 4), (5, 6)]

print map(lambda x,y:x*y,a,b) #[2, 12, 30]匿名函数

# reduce()归并
print reduce(lambda x, y: x + y, range(1,101))#5050从1加到100

写一个函数,用递归的方法实现快速排序,按照升序排列
1. 快速排序就是选定一个标志位,我们把它叫做flag,
把小于flag的放在它的左边,把大于flag的放在它的右边,这样就以flag的分界,
把原来的list分为了两个子list : list1 和 list2。
2. 按照上述方法,在list1 和 list2中再分别选flag,将list2 和 list2 分别拆成两个list,依次类推
3. 直到n = 1,即每个子list都只有一个元素 整个过程 : n/2x = 1 x = log2n

# 练习
# 写一个函数,实现冒泡排序,按照升序排列

def bubble_sort(aList = []):
    if type(aList).__name__=='tuple':
        aList = list(aList)
    if type(aList).__name__=='list':
        if len(aList) <=1:
            return aList
        else:
            for i in range(0,len(aList)-1):
                for j in range(0,len(aList)-i-1):
                    if aList[j]>aList[j+1]:
                        aList[j], aList[j + 1] = aList[j + 1],aList[j]
    return aList

list1 = [20,10,50,30,90]
tuple1 = (20,10,50,30,90)
print bubble_sort(list1)
print bubble_sort(tuple1)

def quick_sort(aList = []):
    if len(aList)<=1:
        return aList
    else:
        flag = aList[0] #任意选一个值作为flag
        smallerList = [] #存放比flag小的值
        biggerList = [] #存放比flag大的值
        flags = []
        for i in aList:
            if i<flag:
                smallerList.append(i)
            elif i>flag:
                biggerList.append(i)
            else:
                flags.append(flag)

        # 递归调用
        smallerList = quick_sort(smallerList)
        biggerList = quick_sort(biggerList)

        return smallerList+flags+biggerList

list2sort = [30,20,10,90,80,50]
print quick_sort(list2sort)