码迷,mamicode.com
首页 > 编程语言 > 详细

正则、冒泡排序、多级排序、FIFO

时间:2017-10-19 17:36:45      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:fifo   父类   out   查找内容   col   tin   构造   sort   观察   

1、删除各行行尾的alex,alex不区分大小写:
import re
s=‘‘‘aLex123
ja654alEx
rain7Alex8
90helloaLeX‘‘‘
#re.M使得^和$由文首、文末变为各行的行首、行末;re.I不区分规则参数的大小写;re.S使.能匹配\n
m=re.sub(‘alex$‘,‘‘,s,count=0,flags=re.M+re.I)
print(m)
**********************分割线**********************
给json的每个key,添加个前缀ids_:
import re
s=‘{"name":"jerry","age":32}‘
#同EditPlus的替换框,group(0)为整个查找内容,group(1)才为其内第1对()中的内容
s=re.sub(‘"(\w+?":)‘,lambda x:‘"ids_‘+x.group(1),s)
print(s)
****************************************分割线****************************************
冒泡排序:
 
t=[87, 69, 42, 25, 10]
for y in range(1,len(t)):   #取出第y大;最末大无需排序
    # 每轮内循环的结果是让最大的去了末尾,故下轮比较不需加它
    for x in range(len(t)-y):  
        if t[x]>t[x+1]:
            tmp=t[x]
            t[x]=t[x+1]
            t[x+1]=tmp
    print(t)
****************************************分割线****************************************
二级排序:先以score排序,score相同的以name排序:
 
class Student:
    def __init__(self,name,score):
        self.name=name
        self.score=score
    def __str__(self):
        return ‘(%s:%d]‘ %(self.name,self.score)
 
L=[Student(‘Tim‘,99),Student(‘Bob‘,88),Student(‘Alice‘,99)]
L=sorted(L,key=lambda x:[x.score,x.name])
print([x.__str__() for x in L])
 
****************************************分割线****************************************
FirstInFirstOut的有序字典:
 
from collections import OrderedDict
 
class FIFO(OrderedDict):
    def __init__(self, capacity=3,*args,**kwargs):
        self.capacity = capacity    #写到super()下面,就报错无capacity属性
        super(FIFO,self).__init__(*args,**kwargs)   #OrderedDict.__init__(self,*args,**kwargs)
 
 
    def __setitem__(self, key, value):
        if key in self:
            print(‘delete existed key:‘,(key,self[key]))
            del self[key]
        elif len(self)==self.capacity:  #表面是批量添加key,实则逐一添加,用>=就画蛇添足了
            front=self.popitem(last=False)
            print(‘delete front key:‘,front)
        # 如同上文的构造函数,要用到父类的同名函数时,须等到结尾,才来显式调用它
        OrderedDict.__setitem__(self, key, value)   #super(FIFO,self).__setitem__(key, value)
 
fd=FIFO(3,{‘w‘:7,‘x‘:8,‘y‘:9,‘z‘:0})
print(fd)
fd.update([(‘a‘,1),(‘b‘,2),(‘c‘,3),(‘d‘,4),(‘e‘,5)])
print(fd)
fd.update({‘f‘:6,‘e‘:9})
print(fd)
****************************************分割线****************************************
类继承中的super:
 
1、super多重继承的构造及实例函数,同普通多继承:广度优先,懒惰模式,即在匹配到第一个长辈类后就终止。
 
2、但是若首个长辈类也有super,就是贪婪模式了:公共爷类(如class E继承了B?C?D,而B?C?D又继承了A),仅执行一次;各父类的super前的代码是广度序,之后的代码是广度序。
 
class A:
    def __init__(self):
        print("Enter A")
        print("Leave A")
 
class B(A):
    def __init__(self):
        print("Enter B")
        super(B, self).__init__()
        print("Leave B")
 
class C(A):
    def __init__(self):
        print("Enter C")
        super(C, self).__init__()
        print("Leave C")
 
class D(A):
    def __init__(self):
        print("Enter D")
        super(D, self).__init__()   #此句取注或注释后,各运行一次,观察两次结果的区别
        print("Leave D")
 
class E(B, C, D):
    def __init__(self):
        print("Enter E")
        super(E, self).__init__()
        print("Leave E")
 
E()

正则、冒泡排序、多级排序、FIFO

标签:fifo   父类   out   查找内容   col   tin   构造   sort   观察   

原文地址:http://www.cnblogs.com/scrooge/p/7693541.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!