re 正则表达式 计算器

海瑞博客-学习python之路•2016-12-01•Python• 59•0A+A-

re是一门小型语言

元字符

.      通配符除了\n

^     以什么开始的匹配

$     以什么结尾的匹配

*     重复前一个条件,最少0个,[0,∞]

+     重复前一个条件,最少1个,[1,∞]

?   重复前面的条件,最少0个,最多1个[0,1]

{x}  重复前面的x次,x为数字,{x,y}最少x次,最多y-1次,{x,}最少x次,最多不限

|     或的意思

\ 反斜杠后跟元字符去除特殊功能

\. 就是匹配点.

\+ 匹配+

\\\\ 匹配\ 等于 r“\\"

r是代表原生字符,不需要python转义就传入re

反斜杠后跟普通字符实现特殊功能

\d 代表数字0-9  [0-9]

\D 代表非数字0-9 [^0-9]

\s 代表匹配空白字符[\t\n\r\f\v]

\S 代表匹配非空白字符 [^\t\n\r\f\v]

\w 代表匹配非空白字符[a-zA-Z0-9]

\W 代表匹配非非字母和数字[^a-zA-Z0-9]

\d 代表匹配一个特殊边界,如匹配单词

字符集

[ ]代表字符集

[a,b,c] 匹配a或b或c中任意一个

[a-z]   匹配a到z中的任意小型字母 [A-Za-z0-9]

- 代表什么到什么之间

^取反的意思,非

\ 将特殊符号转换成普通字符

注:字符集内取消元字符的特殊功能(\ ^ -除外)

[a-z,*] 匹配a-z的字母或*号,还有,号

[^a-z] 匹配非a-z的字母的所有

分组

()代表分组

(1|2)  匹配1或2的字符

(?P<id>\w) 匹配一个字母或数字 这个组的名称是ID

(:?\d+) 取消分组的权限

正则表达式方法

findall(规则,字符串) 寻找所有满足规则的元素

search(规则,字符串) 寻找第一个满足规则的元素并返回一个对象,配合group() 显示内容

 re.search("","1jkj123asda").group() #不建议这样写,如果没找到会报错
#建议以下方法
a = re.search("","1jkj123asda")
if a:a = a.group()
else:print("没有找到")

search

match(规则,字符串) 只在开始匹配规则,满足返回对象,不满足返回None

split(规则,字符串) 通过规则分割字符串 注:先匹配第一个,并分割,再从第一个分割后的匹配第二个,并分割。。。

sub(规则,新内容,字符串) 通过规则匹配字符串内容,并把匹配结果替换成新内容

compile(规则) 将规则封装一个对象中,下次可以直接用对象查询,不需要输规则

finditer(规则,字符串)将查找的结果成一个迭代器,使用next方法取,每个内容用group再取数

习题:

计算器

要求可以计算+ - * \ ()**算法。

计算公式:1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )

思路:

  1. 判断字符串是否包含字母,两个点,括号不相等情况,并去除空白

  2. 提取字符串内的最里面的括号,并返回括号内容

  3. 传递替换 ++  +-  -+  --  *+  /+的操作

  4. 传入其他运算模块 **  // 等

  5. 传入 乘除模块进行计算  返回计算完毕的结果

  6. 传入 加减法模块 计算返回计算结果 返回最终结果

  7. 将结果替换括号,重复前2-7面步骤

  8. 直到无法检测出字符串内包含的+-*/  不包含最后结果

  9. 注意点:*-   /-的问题   负数+正数的问题处理  加减法和乘除法都要按照从左到右计算

  10. 海瑞博客 www.hairuinet.com
     #!/usr/bin/env python
    # -*- coding=utf-8 -*-
    # Created on: 2016年12月11日
    # @author: 郑建文
    # blog:www.hairuinet.com
    import re, time
    def hefaxin(xx):
    '''数据合法性'''
    b = 0
    for i in xx: # 判断
    if b < 0:break
    if i == "(":b += 1
    elif i == ")":b -= 1
    zimu = re.search("[a-zA-Z\=]", xx) # 没有字母为空
    kh = len(re.findall("\d+\.?\d*[\(]", xx)) # 判断括号是否有 数字(的情况
    kh1 = len(re.findall("[()]", xx)) # 判断括号
    dian = re.search("(\d+\.\.\d+)", xx) # 判断是否有 ..
    if kh1 % 2 == b == kh and dian == zimu: return xx.replace(" ", "")
    return 0
    def tihfh(xx):
    '''符号替换'''
    xx = str(xx)
    xx = xx.replace("++", "+")
    xx = xx.replace("+-", "-")
    xx = xx.replace("-+", "-")
    xx = xx.replace("--", "+")
    xx = xx.replace("*+", "*")
    xx = xx.replace("/+", "/")
    return xx
    def ccf(xx):
    '''乘除法'''
    if re.search("\(", xx): xx = xx[1:-1] # 去括号
    while re.search("[\*\/]",xx):
    cenfa = re.search("\d+\.?\d*[\*\/]{1}\-?\d+\.?\d*", xx)
    if cenfa:
    cenfa = cenfa.group()
    if cenfa.count("*") == 1: # 一个乘法
    a, b = cenfa.split("*")
    xx = xx.replace(cenfa, str(float(a) * float(b)))
    elif cenfa.count("*") == 2:
    a, b = cenfa.split("**")
    xx = xx.replace(cenfa, str(float(a) ** float(b)))
    elif cenfa.count("/") == 1:
    a, b = cenfa.split("/")
    xx = xx.replace(cenfa, str(float(a) / float(b)))
    elif cenfa.count("/") == 2:
    a, b = cenfa.split("//")
    xx = re.sub(cenfa, str(float(a) // float(b)), xx)
    else:
    return xx
    return xx
    def jjf(xx):
    '''加减法,按匹配顺序计算'''
    if "(" in xx: xx = xx[1:-1] # 去括号
    while re.search("\d+\.?\d*[\+\-]\d+\.?\d*",xx):
    findret = re.search("[\-]?\d+\.?\d*[\+\-]\d+\.?\d*", xx)
    if findret:
    findret = findret.group()
    if re.search("\d+\.?\d*\+\d+\.?\d*",findret): # 加法
    a, b = findret.split("+")
    xx = xx.replace(findret, str(float(a) + float(b)))
    elif re.search("\d+\.?\d*\-\d+\.?\d*",findret): # 减法
    a, b = findret.split("-")
    xx = xx.replace(findret, str(float(a) - float(b)))
    else:return xx
    return xx
    def kuohao(xx):
    '''寻找括号'''
    xx = re.search("(\([^()]+\))", xx)
    if xx: return xx.group() # 找到就返回找到结果
    return 0 # 没找到返回0
    if __name__ == '__main__':
    while True:
    jishuan = input("请输入公式,保留2位小数。\n绿色为正确,红色结果错误!\n>>>")
    db = hefaxin(jishuan) # 合法性判断
    if db: # 返回正确执行精算
    while db.count("(") > 0: # 循环一直有括号的
    kh = kuohao(db) # 寻找括号
    db = db.replace(kh, str(jjf(ccf(tihfh(kh))))) # 替换括号
    else: # 无括号的情况
    ret = jjf(ccf(tihfh(db)))
    if "+" in ret: ret = ret[1:] # 取正数前面符号
    while len(re.findall("\d+\.?\d*[\+\-\*\/]+\d+\.?\d*",ret)) > 0:
    ret = jjf(ccf(tihfh(ret)))
    if eval(jishuan) == float(ret):s = 32 # 正确就显示绿色
    else:s = 31 # 错误就是红色
    print("\33[%d;1m%s=%.2f\n\33[1m" % (s, jishuan, float(ret)))
    else:print("\33[31;1m程序不合法,无法计算!\33[1m\n\n")
    # 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )"
    #jishuan = "1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )"
    # 2*3*4*-1=6.0*-4.0

    计算器代码

  

Python使用re实现计算器的更多相关文章

  1. 教学项目之-通过Python实现简单的计算器

    教学项目之-通过Python实现简单的计算器   计算器开发需求 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/ ...

  2. 【Python 20】BMR计算器4.0(异常处理)

    1.案例描述 基础代谢率(BMR):我们安静状态下(通常为静卧状态)消耗的最低热量,人的其他活动都建立在这个基础上. 计算公式: BMR(男) = (13.7*体重kg)+(5.0*身高cm)-(6. ...

  3. python实现简单的计算器功能

    如想实现一个计算器的功能,输入格式为字符串,不能运用python里面的内置方法,出去简单的加减乘除,设计一个相对高级的计算器: a = '1 - 2 * ( ( 6 0 -3 0 +(-40/5) * ...

  4. Python基础入门-实现计算器多种姿势

    在Python中,虽然定义一个函数只需要def关键字,但是他能实现多种功能和用途,比如今天我们讲解的这几种方式.如何使用函数实现一个计算器的功能呢?当然,实现计算器的方式有很多种,我们举几个比较典型的 ...

  5. Python带括号的计算器

    带括号的计算器也是第一个自我感觉完成最好的 毕竟真的弄了一个多星期 虽然前期这路真的很难走  我会努力加油  将Python学好学踏实 参考了两位博主的文章 http://www.cnblogs.co ...

  6. 用python实现简单的计算器(加减乘除小括号等)

    需求:实现能计算类似 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) ...

  7. python正则实现简单计算器

    利用正则实现计算器 利用正则来实现简单计算器的功能,能够设计计算带括号的加减乘除运算.当然不使用eval等语句. 利用递归: import re from functools import reduc ...

  8. python + PyQt5 实现 简易计算器

    忽然想起之前一直想写个简单的计算器,今天就写了一下,界面有些简陋,但是基本功能实现没有问题 以下是源码: # --*-- coding:utf-8 --*-- import sys from PyQt ...

  9. 【Python 19】BMR计算器3.0(字符串分割与格式化输出)

    1.案例描述 基础代谢率(BMR):我们安静状态下(通常为静卧状态)消耗的最低热量,人的其他活动都建立在这个基础上. 计算公式: BMR(男) = (13.7*体重kg)+(5.0*身高cm)-(6. ...

随机推荐

  1. 在HTTP响应标题中隐藏ASP.NET MVC的版本

    在默认情况下,ASP.NET MVC网站会在HTTP响应标题(Response Header)中动态添加目前使用的ASP.NET MVC版本编号.如果使用Fiddler Web Debugger工具查 ...

  2. 安装完Ubuntu 14.04要做的九件事

    www.linuxidc.com/Linux/2014-04/100411.htm 1.看看有哪些新特性 安装完之后的第一件事肯定是看看Ubuntu 14.04有哪些新的特性. Ubuntu 14.0 ...

  3. android点滴之标准SD卡状态变化事件广播接收者的注冊

    眼下最完整的,须要注冊的动作匹配例如以下: IntentFilter intentFilter = new IntentFilter(Intent.ACTION_MEDIA_MOUNTED); int ...

  4. 安装Rational Rose启动报错:无法启动此程序,由于计算机中丢失 suite objects.dll。

    执行Rational Rose的时候假设出现这种错误,先检查环境变量有没有common的地址,假设没有直接配上就OK:配置例如以下:D:\Program Files\Rational\Common; ...

  5. Android_listView_exc

    listView布局: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" ...

  6. 深入理解计算机系统第二版习题解答CSAPP 2.4

    不进行数字转换为二进制和十六进制,计算结果. A. 0x503C + 0x8 = 0x5044 B. 0x503C - 0x40 = 0x4FFC C. 0x503C + 64 = 0x503C + ...

  7. 用ModelSim仿真SDRAM操作

    之前写了两篇关于Modelsim仿真的blog,其中模块管脚的命名可能让人觉得有些奇怪,其实不然,之前的两篇内容都是为了仿真SDRAM操作做铺垫的. 由于SDRAM的仿真过程相对比较复杂,也比较繁琐. ...

  8. 读《编写高质量代码:改善JavaScript程序的188个建议》2

  9. 使用T4模板为EF框架添加实体根据数据库自动生成字段注释的功能

    转自http://jeffblog.sinaapp.com/archives/501 首先我们先下载一个文件GetSummery,这里我提供了,大家可以直接下载:下载 我们在数据库建立一个表,并给表中 ...

  10. 第三篇:gradle 编译 Android app 概览

    引言:经过上两篇的论述,我们已经从代码到架构都简单的熟悉了一遍,理论上,只要知道android app的编译过程,我们大可以自己写一份用gradle编译app的插件,插件内将将整个流程用Task的依赖 ...