详解:
1.str.split(分隔符):将str按分隔符进行切片,最后形成的是列表类型
eg:
str = "Line1-abcdef Line2-abc Line4-abcd"; print str.split( ); print str.split(' ', 1 ); >>['Line1-abcdef', 'Line2-abc', 'Line4-abcd'] >>['Line1-abcdef', ' Line2-abc Line4-abcd']
2.str.join():连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串。
语法: 'sep'.join(seq)
参数说明
sep:分隔符。可以为空
seq:要连接的元素序列、字符串、元组、字典
上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串
返回值:返回一个以分隔符sep连接各个元素后生成的字符串
3.sub():按指定的字符进行替换。
Sub(replacement,string[,count =0 ])
1)返回的字符串是在字符串中用RE最左边不重复的匹配来替换。如果模式没有被发现,字符将没有被改变的返回。
2)可选参数count是模式匹配后替换的最大次数;count必须是非负整数。缺省值是0表示替换所有的匹配。
4.grop():获取分段截获的字符串.
需求:
- 实现加减乘除及拓号优先级解析
- 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )等类似公式后,必须自己解析里面的(),+,-,*,/符号和公式。
#coding:utf-8 import re def main(): a = ''.join(raw_input('请输入需要计算的算式').split()) while True: if '(' in a: ct = re.search(r'(([^()]+))', a) if ct is not None: b = ct.groups()[0] c = count(b) a = re.sub(r'(([^()]+))', str(c), a, 1) else: c = count(a) print(c) break def add_min(a): ''' 计算加减法 :param: :return: ''' if '--' in a: a = a.replace('--', '+') c = re.findall(r'-?d+.?d*', a) ls = [] for i in c: ls.append(float(i)) rest = sum(ls) return rest def mul(a): ''' 计算剩数 :param ct: :return: ''' b = re.search(r'd+.?d*(*-?d+.?d*)+', a) if b is not None: b = b.group() rest = 1 c = re.findall(r'-?d+.?d*', b) ls =[] for item in c: ls.append(float(item)) for i1 in range(len(ls)): rest = rest * ls[i1] a = re.sub(r'd+.?d*(*-?d+.?d*)+', str(rest), a, 1) return a def div(a): ''' 计算出发 :param a: :return: ''' b = re.search(r'd+.?d*(/-?d+.?d*)+', a) if b is not None: b = b.group() c = re.findall(r'd+.?d*', b) #print c ls =[] for i in c: ls.append(float(i)) rest = ls[0] for i1 in range(1,len(ls)): rest = rest / ls[i1] a = re.sub(r'd+.?d*(/-?d+.?d*)+', str(rest), a, 1) return a def count(b): ''' 计算结果 :return: ''' while True: if '*' in b: c = b.split('*') if '/' in c[0]: b = div(b) else: b = mul(b) elif '/' in b: b = div(b) elif '+' or '-' in b: b = add_min(b) return b else: return b main()