1.字符串用法
1 name = 'daniel' 2 3 print(name.capitalize()) #首字母大写 4 >>>daniel 5 print(name.count('a')) #统计指定的字符 6 >>>1 7 print(name.center(50,'-')) #一共打印50个字符,不够就用-代替,将name放在中间 8 >>>----------------------daniel---------------------- 9 print(name.endswith('el')) #判断结尾是不是'el' 10 >>>True 11 print(name.expandtabs(tabsize=30)) #如果在一个字符前面输入 (tab)的话就会自动打印三十个空格 12 >>>daniel 13 print(name.find('a')) #查找制定字符的位置 14 >>>1 15 names = '{name} is {year} years old' 16 print(names.format(name='Daniel',year=18)) #为临时变量赋值 17 >>>Daniel is 18 years old 18 print(name.index('d')) #获取指定字符的下标 19 >>>0 20 print(name.isdigit()) #判断变量是否是证书 21 >>>Flase 22 print(name.isalnum()) #判断变量是否为阿拉伯字符(包含数字和英文) 23 >>>True 24 print(name.isalpha()) #判断变量是否为纯英文字符 25 >>>True 26 print(name.isdecimal()) #判断变量为10进制数字 27 >>>False 28 print(name.isidentifier()) #判断是不是一个合法的变量名 29 >>>True 30 print(name.islower()) #判断变量是否为小写 31 >>>True 32 print(name.isnumeric()) #判断变量是否只有数字 33 >>>False 34 print(name.istitle()) #判断变量是否是首字母大写(每个单词) 35 >>>False 36 print(name.isprintable()) #判断是否能打印 37 >>>True 38 print(name.isupper()) #判断是否全部都是大写 39 >>>False 40 print('+'.join(['1','2','3'])) #将列表中的东西加入到'+',不能是str,如果是数字就要''放入 41 >>>1+2+3 42 print(name.ljust(50,'*')) #打印五十个字符,不够就用*代替放在右边 43 >>>daniel******************************************** 44 print(name.lrjust(50,'*')) #与上面相反 45 print(name.lower()) #将大写变成小写 46 >>>daniel 47 print(name.upper()) #将小写变成大写 48 >>>DANIEL 49 print(' Danile'.lstrip) #删除左边的空格 50 print('Daniel '.rstrip) #删除右边的空格 51 print(' Daniel '.strip) #删除所有的空格 52 print('DanielDD'.replace('D','d',1)) #替换后面的1表示只替换第一个 53 >>>danielDD 54 print('Daniel DD'.rfind('D')) #找到指定的值的最右边的下标 55 >>>8 56 print('Daniel 1 2 3 4'.split()) #使用指定的字符为分隔符,分割成列表,默认为空格 57 >>>['Daniel', '1', '2', '3', '4'] 58 print('Daniel 1 2 3 4'.splitlines()) #同上,可识别不同系统 59 print('Dianiel'.swapcase()) #大写变小写 60 >>>dANIEL 61 name = "Daniel","Man" 62 print('is'.join(name)) #字符串拼接 63 >>>Danieliszhaoyue
2.集合操作
集合是一个无序的,不重复的数据组合,它的主要作用如下:
- 去重,把一个列表变成集合,就自动去重了
- 关系测试,测试两组数据之前的交集、差集、并集等关系
常用操作:
a = set([1,2,3,4,5]) #创建数值集合 b = set(['Hello']) #创建字符集合 c = set([1,3,5,888]) print(a | b) #a和b的并集 print(a.union(b)) #同上 >>>{1, 2, 3, 4, 5, 'Hello'} print(a & c) #a和c的交集 print(a.intersection(c)) #同上 >>>{1, 3, 5} print(a - c) #a和c的差集 print(a.difference(c)) #同上 >>>{2, 4} print(a ^ c) #对称差集,在a或b中,不会同时在两者中 print(a.symmetric_difference(c)) #同上 >>>{2, 4, 888}
基本操作:
1 c.add('xxx') #添加一项 2 a.update([111,222,333]) #添加多项 3 print(a,c) 4 >>>{1, 2, 3, 4, 5, 333, 111, 222} {1, 3, 5, 'xxx', 888} 5 6 a.remove(5) #删除一项 7 print(a) 8 >>>{1, 2, 3, 4, 333, 111, 222} 9 10 print(len(a)) #a的长度,跟list的index一样 11 >>>7 12 13 print(3 in a) #判断3是不是在a里面,也可以判断其它的集合 14 >>>True 15 16 print(3 not in a) #与上相反 17 >>>False 18 19 print(b.issubset(a)) #判断b中的所有元素a里面是否都有 20 print(b <= a) #意思同上 21 >>>Flase 22 23 print(b.issuperset(a)) #判断a里的所有元素b是否全有 24 print(b >= a) #意思同上 25 >>>Flase
3.文件操作
对文件操作流程
- 打开文件,得到文件句柄并赋值给一个变量
- 通过句柄对文件进行操作
- 关闭文件
基本操作:
文件内容:
1 你等着一辆火车, 2 它会把你带到远方. 3 你明白自己希望火车把你带到哪儿, 4 不过你也心存犹豫, 5 但这一切都没有关系. 6 ——因为我们在一起.
1 f = open('E:/python/file/test.txt') 2 print('first line:',f.readline()) 3 >>>first line: 你等着一辆火车, 4 print(f.read()) 5 >>>它会把你带到远方. 6 你明白自己希望火车把你带到哪儿, 7 不过你也心存犹豫, 8 但这一切都没有关系. 9 ——因为我们在一起.
打开文件的模式有:
- r,只读模式(默认)。
- w,只写模式。【不可读;不存在则创建;存在则删除内容;】
- a,追加模式。【可读; 不存在则创建;存在则只追加内容;】
"+" 表示可以同时读写某个文件
- r+,可读写文件。【可读;可写;可追加】
- w+,写读
- a+,同a
"U"表示在读取时,可以将 自动转换成 (与 r 或 r+ 模式同使用)
- rU
- r+U
"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)
- rb
- wb
- ab
其它语法:
1 f.tell() #查看现在的光标位置 2 3 f.seek(0) #指定光标回到哪里,多用于文件重新读取,和tell一起使用 4 5 f.flush() #刷新 6 7 f.truncate(10) #截断,默认从0开始,后面是结束 8 print(f.read()) 9 >>>你等着一辆
补充:
1 #with 语句 2 #为了避免打开文件后忘记关闭,可以通过管理上下文,即: 3 4 with open('file','r') as f: #与f = open('file','r')一样 5 6 7 如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。 8 9 在Python 2.7 后,with又支持同时对多个文件的上下文进行管理,即: 10 11 with open('file1','r') as f1 , open('file2','r') as f2:
4.字符转编码操作:
超级超级详细版!!!>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>http://www.cnblogs.com/yuanchenqi/articles/5956943.html
1).在python2默认编码是ASCII, python3里默认是unicode
2).unicode 分为 utf-32(占4个字节),utf-16(占两个字节),utf-8(占1-4个字节), so utf-16就是现在最常用的unicode版本, 不过在文件里存的还是utf-8,因为utf8省空间
3).在py3中encode,在转码的同时还会把string 变成bytes类型,decode在解码的同时还会把bytes变回string
文件操作小实例
要求:
现有配置文件httpd.conf,内容如下:
<VirtualHost *:80>
DocumentRoot /var/www/html/
ServerName www.baidu.com
ErrorLog "logs/baidu.com-error.log"
CustomLog "logs/baidu.com-access.log" common
</VirtualHost>
backend www.baidu.com
server 1.1.1.1 1.1.1.1 weight 100 maxconn 2000
server 2.2.2.2 2.2.2.2 weight 100 maxconn 2000
backend www.sina.com
server 3.3.3.3 3.3.3.3 weight 100 maxconn 3000
server 4.4.4.4 4.4.4.4 weight 100 maxconn 3000
对这个文件可进行增删查改操作
增加:是增加一条backend记录,是一整块,包括下面的server
删除:可以删除一条server
查询:查询到输入的backend"xxx.xxx.com"以下的server内容
修改:改backend记录中的一条server
1 # -*-conding:utf-8-*- 2 #Author:Daniel 3 4 import os 5 6 def file_operation(filename,data_backend,return_list,type): 7 ''' 8 统一文件操作接口 9 :param filename: 传入原文件名字 10 :param data_backend: 自己拼接一个完整的"backend" 11 :param return_list: "backend"下"server"字段,以一个列表存放 12 :param type: 文件类型,用于具体操作文件 13 :return: 14 ''' 15 if type == 'query': 16 tag = False 17 data_list = [] 18 with open(filename, 'r') as f: 19 for i in f: 20 if i.strip() == data_backend: 21 tag = True 22 continue 23 if tag and i.startswith("backend"): 24 tag = False 25 break 26 if tag and i: 27 data_list.append(i.strip()) 28 return data_list 29 elif type == 'add': 30 with open(filename, 'r') as read_file, 31 open("haproxy_new.txt", 'w') as write_file: 32 for i in read_file: 33 write_file.write(i) 34 for i in return_list: 35 if i.startswith("backend"): 36 write_file.write(i + " ") 37 else: 38 write_file.write("%s%s " % (' ' * 4, i)) 39 os.remove(filename) 40 os.rename("haproxy_new.txt", filename) 41 elif type == 'change': 42 with open(filename, 'r') as read_file, 43 open("haproxy_new.txt", 'w') as write_file: 44 tag = False 45 tag_2 = False 46 for i in read_file: 47 if i.strip() == data_backend: 48 tag = True 49 continue 50 if i.startswith("backend"): 51 tag = False 52 if not tag: 53 write_file.write(i) 54 else: 55 if not tag_2: 56 for i in return_list: 57 if i.startswith("backend"): 58 write_file.write(i + " ") 59 else: 60 write_file.write("%s%s " % (' ' * 4, i)) 61 tag_2 = True 62 os.remove(filename) 63 os.rename("haproxy_new.txt", filename) 64 65 else: 66 print("啥也不是") 67 68 def query(data): 69 ''' 70 用户查询接口 71 :param data:用户输入的数据,例子:www.baidu.com 72 :return: 73 ''' 74 data_backend = "backend %s" % data 75 return_list = file_operation('haproxy.txt',data_backend,None,type='query') 76 for i in return_list: 77 print(i) 78 return return_list 79 80 def add(data): 81 ''' 82 用户添加接口 83 :param data:用户输入的数据,必须是字典形式,例如{"backend":"www.faker.com","server":"6.6.6.6","weight":"20","maxconn":3000} 84 这里,文件如果没有backend字段会将这个字典存进去,如果有则会存server字段 85 :return: 86 ''' 87 backend = data["backend"] #取值 88 return_list = query(backend) #取值,query函数返回的一个列表 89 data_backend = "backend %s" % backend #自己拼接的backend字段 90 server_value = "server %s %s wieght %s maxconn %s" % (data["server"], 91 data["server"], 92 data["weight"], 93 data["maxconn"]) #自己拼接的server字段 94 if not return_list: 95 return_list.append(data_backend) 96 return_list.append(server_value) 97 file_operation("haproxy.txt",data_backend,return_list,type="add") 98 else: 99 return_list.insert(0,data_backend) 100 if server_value not in return_list: 101 return_list.append(server_value) 102 file_operation("haproxy.txt", data_backend, return_list, type="change") 103 104 def remove(data): 105 ''' 106 用户删除接口 107 :param data: 用户输入的数据,必须是字典形式,例如{"backend":"www.faker.com","server":"6.6.6.6","weight":"20","maxconn":3000} 108 这里,文件如果没有backend字段或者server字段会出现提示信息,如果有则删除server字段 109 :return: 110 ''' 111 backend = data["backend"] 112 return_list = query(backend) 113 data_backend = "backend %s" % backend 114 server_value = "server %s %s weight %s maxconn %s" % (data["server"], 115 data["server"], 116 data["weight"], 117 data["maxconn"]) 118 if not return_list or server_value not in return_list: 119 print("