re模块

re:其实就是带有特殊语法的字符串

语法:单个字符和多个字符

单个字符:

\d是匹配所有的数字

\D是匹配所有的非数字

\s是所有的换行符,制表符,空白等,回车符

\S是所有费换行符,空白和制表符等

\w字母数字下划线

\W所有非字母数字下划线

.匹配所有单个字符,(不包括换行符)

多个字符:

+==》{1,n}n是代表所取的个数,是贪婪匹配,能匹配多个就匹配多个

*==》{0,n}n是代表所取的个数,是贪婪匹配,能匹配多个就匹配多个

?==》{0,1}是贪婪匹配,也是能匹配多个就匹配多个

*****************************************************************************************************

+?结合在一起就是非贪婪匹配,是{1,n}但是能不匹配就不匹配,一般结合^$来使用,也是非单个字符匹配

*?结合在一起就是非贪婪匹配,是{0.1},也是要结合^$在一起使用,非单个字符是没有意义的

.+:所有的匹配,除了换行符,贪婪匹配,最少匹配要看匹配前面的匹配对象

.*:所有的匹配,除了换行符,但是是从0开始,最少匹配是空格

.+?:是非贪婪匹配

.*?:也是非贪婪匹配,匹配多少还是要看匹配前面的匹配对象

####所谓的贪婪非贪婪指的是要匹配的字符,+?这个是前面的必须全部匹配,可以不取后面的  *?是可以将前面要匹配的少一个字符,可以不取后面的

多行:

re.S能让.也可以匹配到\n

re.M多行匹配,可以全部读取出来

re.I不区分大小写匹配

分组:

1.从左往右数左括号,对‘(’进行编号,自己的分组从1开始,group(0)代表匹配的目标整体。

2.(?:)取消所属分组,()就是普通的(),可以将里面的信息作为整体包裹,但是不产生分组

替换sub

1.不参与匹配的原样带下

2.参与匹配的都会被替换成指定字符串

3.在指定字符串\num会拿到具体分组(注意转义)

4.其他字符都是原样字符串

切分split:将字符串切分成单个字符串列表

面向对象

1、面向过程编程
核心是"过程"二字,过程指的是解决问题的步骤,即先干什么再干什么
基于该思想编写程序就好比在编写一条流水线,是一种机械式的思维方式

如所写的函数等就是直接面向过程,解决问题,就是直接自己去解决问题,没有找中间

优点:复杂的问题流程化、进而简单化
缺点:可扩展性差

2、面向对象
核心"对象"二字,对象指的是特征与技能的结合体,
基于该思想编写程序就好比在创造一个世界,你就是这个世界的上帝,是一种
上帝式的思维方式

优点:可扩展性强
缺点:编程的复杂度高于面向过程
所写的东西就是直接面向对象,不在从过程考虑问题,只考虑找到怎么找到一个对象解决这个问题

相同点:两者都是最终都是要去解决问题

区别:面向过程:直接解决问题,将问题流程化,进而简单化。    面向对象:直接找到解决问题的对象,让这个对象去自己想办法解决

重点:面向对象的核心体现是将数据和处理数据的程序封装到对象中

其实就是将属性和方法都放到封装到对象里面,只管对象,对象自己管自己的里面的东西

*函数和方法的区别

函数:通过函数名直接调用

方法:通过附属者.语法调用

变量:通过变量名访问变量值

属性:通过附属者.语法来访问变量值

名称空间

函数可以产生自己的局部名称空间,文件可以产生自己的全局名称空间(我们平时所说的全局名称空间其实就是文件的全局名称空间)

名称空间就是存放名字和地址的一个字典,所以key对应的value就是名字:地址{‘name':地址}

但是如果是int和float,由于是不可变类型,所以直接显示值,其他的显示的是存放值的地址

查看re和函数的名称空间

import re
print(re.__dict__) #{'__name__':'re','__doc__':'地址'}
def fn():
pass
print(fn.__dict__) #{}未定义就是一个空列表 _______________________________________________________________________________
可以添加内容
import test#文件只要被引用,里面的内容就会直接被打印,文件导入执行三步骤!
print(test.__dict__)#{'__name__':'test','__doc':'None'.....}文件也有自己的名称空间
import re
res=re.__dict__['name']='owen'
rea=re.__dict__['sys']='测试'
ren=re.__dict__
ren.update(name='egon')
print(re.sys)
print(re.__dict__)
#所以可以对名称空间进行字典的操作 ————————————————————————————————————————————————————————————————————————————————
可以直接在名称空间里面添加一个匿名函数,引用
#value存的是地址,直接引用匿名函数,不加()就是函数对象,结果就是对象地址
re.__dict__['action']=lambda x:x
print(re.__dict__['action'])#<function <lambda> at 0x000001C922D91EA0> #在加上()后就是函数运行后的结果,所以是100
print(re.__dict__['action'](100))#100 ++++++++++++++++++++++++++++++++++++++++++++++
可以直接把一个函数方法封装在另一个名称空间里,通过.语法调用可以直接调用该方法

# def fn():
# pass
# print(fn.__dict__)#{}
# fn.name='fn函数'
# # print(fn.name)#fn函数 可以直接通过.语法加key值
#
# def tst():
# print('成为海贼王的男人')
# fn.action=tst#直接给fn封装一个tst函数方法
# fn.action() 类与对象的概念
类:具有相同特征和行为个体集合的抽象
对象:有特征和行为的具体的个体。就是类的具体体现
区别:两个人同时思考一个名字,想到的是同一个物体,就一定是对象,反之,一定是类 语法
类的声明:
class:关键字
class 类名:
pass
##对象的产生:对象的实例化
对象1=类名()
对象2=类名()
对象3=类名() 类与对象都有自己独立的名称空间,每一个被实例化出来的对象,名称空间也是独立存在
所以类与对象都能额外添加属性(变量)和方法(函数)
重点:类随着文件的加载而加载(类一旦被加载),就会进入类的内部,执行类内部的代码(但是不进入到对象中) 属性:通过附属者.语法来访问的变量值 ####对象查找属性顺序为:优先自身,自身没有的进入类
#对象查找属性的顺序
class People:
identify='人类'
def study(self):
print('好好学习,天天向上')
p1=People()#产生对象p1
p2=People()#产生对象p2
p1.identify='新新人类'
print(p1.identify)#新新人类 访问的是自己的identify
print(p2.identify)#人类 未定义访问类中的identify
del p1.identify#删除自己的identify后
print(p1.identify)#人类 访问的是类中的identify
p2.identify='机器人'
print(p2.identify)#机器人
p2.__dict__.clear()
print(p2.identify)#人类
People.study((1,2,3))#好好学习,天天向上
————————————————————————————————————————————————————————————
类产生对象,类是由元类产生,元类?

re模块+面向对象的更多相关文章

  1. 自学Python之路-Python基础+模块+面向对象+函数

    自学Python之路-Python基础+模块+面向对象+函数 自学Python之路[第一回]:初识Python    1.1 自学Python1.1-简介    1.2 自学Python1.2-环境的 ...

  2. Python 编程核心知识体系-模块|面向对象编程(三)

    模块 面向对象编程

  3. Python(三)基础篇之「模块&面向对象编程」

    [笔记]Python(三)基础篇之「模块&面向对象编程」 2016-12-07 ZOE    编程之魅  Python Notes: ★ 如果你是第一次阅读,推荐先浏览:[重要公告]文章更新. ...

  4. python-文件操作&模块&面向对象

    python 文件处理 li = [[']] for i in li: print(','.join(i)) # join字符串拼接 语文,数学,英语 100,122,123 从原文件末尾开始写入 # ...

  5. 第三模块 面向对象& 网络编程基础 实战考核

    1.简述构造方法和析构方法. 构造方法(__init__):主要作用是实例化时给实例一些初始化参数,或执行一些其它的初始化工作,总之因为这个__init__只要一实例化, 就会自动执行,不管你在这个方 ...

  6. python常用模块及面向对象(一)

    目录: 常用模块之time模块 常用模块之random模块 常用模块之os模块 常用模块之sys模块 常用模块之subprocess模块 常用模块之json模块 常用模块之pickle模块 常用模块之 ...

  7. 第三模块:面向对象&网络编程基础 第2章 网络编程

    01-计算机基础 02-什么是网络 03-五层协议详解 04-传输层详解 05-什么是Socket 06-基于socket实现简单套接字通信 07-在简单套接字基础上加上通信循环 08-客户端与服务端 ...

  8. 第三模块:面向对象&网络编程基础 第1章 面向对象

    我的失败与梦想(一) 我的失败与梦想之为何创办路飞学城 01-编程范式 02-面向过程编程 03-面向对象编程介绍 04-定义类与实例化出对象 05-如何使用类 06-如何使用对象 07-属性查找与绑 ...

  9. python面向对象(一),Day6

    connfigparser模块 xml模块 shutil模块以及压缩解压 subprocess模块 面向对象(上) 类和对象 onfigParser 用于对特定的配置进行操作,当前模块的名称在 pyt ...

随机推荐

  1. Gis数据处理

    几何投影和解析投影几何投影是将椭球面上的经纬线网投影到几何平面上,然后将几何面展为平面.几何投影可以分为方位投影.圆柱投影和圆锥投影.这三种投影纬线的形状不同.方位投影纬线的形状是同心圆:圆柱投影纬线 ...

  2. PTA第一个编程题总结

    7-1 打印沙漏 (20 分) 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个“*”,要求按下列格式打印 ***** *** * *** ***** 所谓“沙漏形状”,是指每行输出奇数 ...

  3. demo1:会下蛋的机器人

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 怎样从外网访问内网Sysbase数据库

    外网访问内网Sysbase数据库 本地安装了Sysbase数据库,只能在局域网内访问,怎样从外网也能访问本地Sysbase数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Sys ...

  5. List添加map,后添加的map覆盖前面的问题

    List resultList = new ArrayList(); Map map = new HashMap(); while(rs.next()){ String userid = rs.get ...

  6. MySQL插入去重命令_INSERT IGNORE INTO

    之前在介绍INSERT INTO命令时,曾经提到,该命令在执行数据插入操作时,会在数据库中对元组的主键进行检测,若没有存在,则执行插入动作,若存在,则会报错. 而INSERT IGNORE INTO命 ...

  7. P2877 [USACO07JAN]牛校Cow School(01分数规划+决策单调性分治)

    P2877 [USACO07JAN]牛校Cow School 01分数规划是啥(转) 决策单调性分治,可以解决(不限于)一些你知道要用斜率优化却不会写的问题 怎么证明?可以暴力打表 我们用$ask(l ...

  8. 也说性能测试,顺便说python的多进程+多线程、协程

    最近需要一个web系统进行接口性能测试,这里顺便说一下性能测试的步骤吧,大概如下 一.分析接口频率 根据系统的复杂程度,接口的数量有多有少,应该优先对那些频率高,数据库操作频繁的接口进行性能测试,所以 ...

  9. systemd 服务介绍

    CentOS7自定义系统服务 CentOS7的服务systemctl脚本存放在:/usr/lib/systemd/,有系统(system)和用户(user)之分,需要开机不登陆就能运行的程序,存在系统 ...

  10. webpack搭建项目时出现的报错“Module build failed (from ./node_modules/css-loader/dist/cjs.js) CssSyntaxError”

    控制台出现的错误如下: webpack.config.js中的配置如下: module.exports={ entry:'./src/main.js', output:{ path:__dirname ...