Python之路---day2

一: 作用域

对于变量的作用域,只要内存中存在,该变量就可以使用。

二:三元运算

name = 值1 if 条件 else 值2

如果条件为真:result = 值1

如果条件为假:result = 值2

方式一:

name = 'ccc'
if 
1==1:
    name = 'sb'
else
:
    name = 'sb'
方式二:
name = 'sb' if 1==else '2b'

实例:

name = raw_input('your name: ')
reslut = 'sb' if name == 'alex' else 'nice'

print reslut

三:进制

 

python的一切事物都是对象。对象是基于类创建的。

查看list这个类有哪些方法

dir(类型名)

help(类型名)

把详细的内容显示出来

help(类型名.功能名)

通过type()查看对象的类型

实例:

print dir(list)

print help(list)

print help(list.append)

类中的方法分为带下划线和不带下划线的。

带下划线的是内置方法,可能有多种执行方法;

不带下划线的是非内置方法,只有一种执行方法;对象.方法

对于上面那句话的理解

一:数字

i = 10
i1 = int(10)
i2 = int("10",2)

后面的数字表示进制,前面的是进制下对应的值

下面是int中的部分方法

 

 1 #比较大小
 2 
 3 age = 18
 4 print age.__cmp__(19)
 5 print age.__cmp__(18)
 6 print age.__cmp__(17)
 7 print cmp(18,19)
 8 #取绝对值
 9 a = -9
10 print a.__abs__()
11 #相加
12 b = 9
13 print b.__add__(8)
14 #强制生成一个元组
15 c = 7
16 print c.__coerce__(6)
17 #取商和余数,计算分页使用
18 d = 98
19 print d.__divmod__(10)
20 #取商
21 e = 9
22 print e.__div__(3)
23 #转换为浮点类型
24 f = 7
25 f1 = f.__float__() 
26 
27 print type(f1)
28 
29 #哈希值用于在字典中快速找到他的键

二:字符串(str)

 1 str_1 = "alex"
 2 str_2 = str("alex")
 3 #首字母变大写
 4 
 5 print str_2.capitalize()
 6 
 7 #将内容显示在中间;总长度是20;以*填充
 8 
 9 print str_2.center(20)
10 print str_2.center(20,"*")
11 #子序列个数;d的个数;从0-10的位置找
12 name = "dfghjdfghjdfghdfghdfg"
13 print name.count('d')
14 print name.count('d',0,10) 

###############################################################

编码的转化  gbk==>unicode==>utf-8

encode:编码

decode:解码  

 1 >>> '我靠' 
 2 
 3 '\xce\xd2\xbf\xbf'
 4 >>> str1 = '\xce\xd2\xbf\xbf'
 5 >>> print str1
 6 我靠
 7 >>> str1.decode('gbk')
 8 u'\u6211\u9760'
 9 >>> str1.decode('gbk').encode('utf-8')
10 '\xe6\x88\x91\xe9\x9d\xa0'
11 >>> print str1.decode('gbk').encode('utf-8') 
12 
13 鎴戦潬 

编码解释

###############################################################

 1 #以什么结尾;是在返回true
 2 str_1 = "alex"
 3 print  str_1.endswith('x')
 4 #将tab转换成空格,默认一个tab转换成8个空格;转换成1个
 5 name = 'ale     x'
 6 print name.expandtabs()
 7 print name.expandtabs(1)
 8 #寻找子序列的位置;-1表示没有找到
 9 print str_1.find('e')
10 print str_1.find('le')
11 print str_1.find('s')
12 #找到第一个
13 str2 = "alexa"
14 print str2.find('a')
15 #字符串格式化
16 ##按照下标(有序的)
17 name = "i am {0},age {1}"
18 print name.format("cgt",24)
19 ##使用列表的方式
20 name_list = ["cgt",24]
21 print name.format(*name_list)
22 ##按照名称(无序的)
23 name = "i am {aa},age {bb}"
24 print name.format(aa="cgt",bb=24)
25 print name.format(bb=24,aa="cgt")
26 ##使用字典的方式
27 name_dict = {'aa':'cgt','bb':24}
28 print name.format(**name_dict)
29 #使用index来查找;找不到就报错,而find是返回-1
30 name = "alex"
31 print name.index('a')
32 #是否是数字和字母
33 print name.isalnum()
34 #是否是字母
35 print name.isalpha()
36 #是否是数字
37 print name.isalnum()
38 #是否是小写
39 print name.islower()
40 #是否是空格
41 print name.isspace()
42 #是不是标题istitle(标题的格式就是单词的首字母大写)
43 print name.istitle()
44 #设置为标题的格式title
45 print name.title()
46 #是不是大写isupper
47 print name.isupper()
48 #连接join
49 print '__'.join(name)
50 #内容左对齐ljust(宽度,填充)
51 print name.ljust(20,'*')
52 #内容右对齐rjust(宽度,填充)
53 print name.ljust(20,'&')
54 #变成小写lower
55 print name.lower()
56 #变成大写upper
57 print name.upper()
58 #大小写交换swapcase
59 name = "AleX"
60 print name.swapcase()
61 #移除左边的空白lstrip
62 print name.lstrip()
63 #分隔partition(前,中,后)
64 name = "hello cgt"
65 print name.partition("ll")
66 #替换replace(old,new)
67 name = 'alex'
68 print name.replace('a','b')
69 #从右边开始找rfind
70 print name.rfind('e')
71 #以什么开始
72 print name.startswith('a') 

三:列表(list)

 1 #定义一个列表
 2 
 3 li = [11,22,33,11]
 4 #append添加
 5 print li.append(12)
 6 #count出现的次数
 7 print li.count(11)
 8 #extend扩展
 9 print li.extend(['ccc','ggg'])
10 #index返回第一个匹配的值的下标,不存在,报错
11 
12 print li.index(11) 
13 
14 #insert插入,在指定位置插入(位置,内容)
15 
16 li.insert(4,'aa') 
17 
18 #pop删除并返回指定下标的值,如果没有指定在返回最后一个的值
19 li = [11,22,33,11,'alex']
20 name = li.pop(11)
21 name2 = li.pop()
22 #remove移除;指定值,不是指定下标。只删除第一个的值
23 
24 li.remove(11) 
25 
26 #reverse反转列表
27 
28 li.reverse() 
29 
30 #sort排序
31 
32 li.sort() 

四:元组

元组的元素不能被修改,但是元组的元素的元素是可以修改的

count

index

五:字典

#判断元素的类型是不是某种类型

#例子

#type(name) is list  

 1 dic = {'k1':'aa','k2':'bb','k3':'cc'}
 2 #清除内容
 3 #a = dic.clear()
 4 #print  a
 5 #根据key获取值
 6 print dic['k1']
 7 print dic.get('k1')
 8 #如果key值不存在,不使用get的方式会报错;使用get的方式,可以实现设置默认的值,如果这个key存在,则不打印默认值
 9 #print dic['k4']
10 print dic.get('k4','ok')
11 #判断是否有key
12 print dic.has_key('k5')
13 #所有项的列表形式
14 print dic.items()
15 #所有key的列表
16 print dic.keys()
17 ##判断是否有key
18 for k in dic:
19     print k,dic[k]
20 #获取显示出来并在字典中移除
21 '''
22 print dic.pop('k1')          #指定key删除
23 print dic.popitem()          #随机的删除
24 
25 '''
26 
27 dic = {'k1':'aa','k2':'bb','k3':'cc'}
28 #清除内容
29 #a = dic.clear()
30 #print  a
31 #根据key获取值
32 print dic['k1']
33 print dic.get('k1')
34 #如果key值不存在,不使用get的方式会报错;使用get的方式,可以实现设置默认的值,如果这个key存在,则不打印默认值
35 #print dic['k4']
36 print dic.get('k4','ok')
37 #判断是否有key
38 print dic.has_key('k5')
39 #所有项的列表形式
40 print dic.items()
41 #所有key的列表
42 print dic.keys()
43 ##判断是否有key
44 for k in dic:
45     print k,dic[k]
46 #获取显示出来并在字典中移除
47 '''
48 print dic.pop('k1')          #指定key删除
49 print dic.popitem()          #随机的删除
50 
51 '''
52 
53 #copy:浅拷贝和深拷贝、别名的区别
54 
55 >>> dic
56 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'}
57 >>> copy_dic = dic.copy()
58 >>> copy_dic
59 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'}
60 >>> second_dic = dic
61 >>> second_dic
62 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'}
63 >>> dic
64 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'}
65 >>> second_dic
66 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'}
67 >>> copy_dic       
68 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'}
69 >>> dic['k4']='dd'
70 >>> dic
71 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa', 'k4': 'dd'}
72 >>> second_dic   
73 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa', 'k4': 'dd'}
74 >>> copy_dic      
75 
76 {'k3': 'cc', 'k2': 'bb', 'k1': 'aa'} 

六:集合(是一个无序且不重复的元素集合)  

 1 >>> a = range(5,10)
 2 >>> b = range(7,12)
 3 >>> a
 4 [5, 6, 7, 8, 9]
 5 >>> b 
 6 
 7 [7, 8, 9, 10, 11] 
 8 
 9 #将a列表set成集合
10 
11 >>> c = set(a)
12 >>> c 
13 
14 set([8, 9, 5, 6, 7]) 
15 
16 #在a列表追加一个 6,重新set后只显示一个6 
17 
18 >>> a.append(6)
19 >>> a
20 [5, 6, 7, 8, 9, 6]
21 >>> c = set(a)
22 >>> c
23 set([8, 9, 5, 6, 7])
24 >>> d = set(b)
25 >>> c,d 
26 
27 (set([8, 9, 5, 6, 7]), set([8, 9, 10, 11, 7])) 
28 
29 #取交集
30 
31 >>> c & d 
32 
33 set([8, 9, 7]) 
34 
35 #取合集
36 
37 >>> c | d 
38 
39 set([5, 6, 7, 8, 9, 10, 11]) 
40 
41 #取交集的补集
42 
43 >>> c ^ d 
44 
45 set([5, 6, 10, 11]) 
46 
47 #取差集
48 
49 >>> c - d 
50 
51 set([5, 6]) 
52 
53 #是否是子集
54 
55 >>> e = set([8,9])
56 >>> e
57 set([8, 9])
58 >>> e.issubset(d) 
59 
60 True 
61 
62 #是否是父集
63 
64 >>> e.issuperset(d)
65 False
66 >>> e
67 set([8, 9])
68 >>> e.pop()
69 8
70 >>> e
71 set([9])
72 >>> d
73 set([8, 9, 10, 11, 7])
74 >>> d.remove(9)
75 >>> d
76 set([8, 10, 11, 7])
77 >>> e
78 set([9])
79 >>> d
80 set([8, 10, 11, 7])
81 >>> d.update(e)
82 >>> d 
83 
84 set([7, 8, 9, 10, 11]) 

七:时间

有三种形式:时间戳、格式化  

 1 import  time 
 2 print time.time()
 3 #以时间戳的形式存在
 4 #1445324355.64
 5 print time.gmtime()
 6 #time.struct_time(tm_year=2015, tm_mon=10, tm_mday=20, tm_hour=6, tm_min=59, tm_sec=15, tm_wday=1, tm_yday=293, tm_isdst=0)
 7 print time.strftime('%Y-%m-%d %H:%M:%S')
 8 #自定义格式
 9 
10 #2015-10-20 15:00:52
11 
12 print time.strptime('2014-11-11', '%Y-%m-%d')
13 #将格式化的时间转成一个结构化的时间
14 
15 #time.struct_time(tm_year=2014, tm_mon=11, tm_mday=11, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=1, tm_yday=315, tm_isdst=-1)
16 
17 print time.localtime()
18 #是一个结构化的时间

 

 

posted @ 2015-11-04 11:05  曹小贱  阅读(234)  评论(0编辑  收藏  举报