先学习之前未完成的冒泡算法

li = [13,22,6,99,11]

从小到大

从第一个数字比较把大的往后移位

for m in range(4):

  num1 = li[m]

  num2 = li[m+1]

  if num1 > num2:

    temp = li[m]

    li[m] = num2

    li[m+1] = temp

print li

循环四次就把最大数放到列表的最后

for m in range(3):

  num1 = li[m]

  num2 = li[m+1]

  if num1 > num2:

    temp = li[m]

    li[m] = num2

    li[m+1] = temp

以此类推写成以下代码

vim day4-1.py

#!/usr/bin/python
# -*- coding:utf-8 -*-

li = [13,22,6,99,11]
for m in range(4): #循环
num1 = li[m]
num2 = li[m+1]
if num1 > num2: #前一个数字和后一个对比如果前面数字大与后面的对调
temp = num1
li[m] = num2
li[m+1] = temp
print li for m in range(3):
num1 = li[m]
num2 = li[m+1]
if num1 > num2:
temp = num1
li[m] = num2
li[m+1] = temp print li for m in range(2):
num1 = li[m]
num2 = li[m+1]
if num1 > num2:
temp = num1
li[m] = num2
li[m+1] = temp print li for m in range(1):
num1 = li[m]
num2 = li[m+1]
if num1 > num2:
temp = num1
li[m] = num2
li[m+1] = temp print li #多次循环得到排序结果

  

[root@VPN scripts]# python day4-1.py
[13, 6, 22, 11, 99]
[6, 13, 11, 22, 99]
[6, 11, 13, 22, 99]
[6, 11, 13, 22, 99]

这样的循环很繁琐,假如不知道列表的长度更加麻烦需要多次循环

vim day4-2.py

#!/usr/bin/python
# -*- coding:utf-8 -*-
li = [13,22,6,99,11]
for n in range(1,len(li)-1): #外层循环1,2,3,4
for m in range(len(li)-n): #内层循环4,3,2,1
num1 = li[m]
num2 = li[m+1]
if num1 > num2:
temp = li[m]
li[m] = li[m+1]
li[m+1] = temp
print li

  运行结果的一样的

[root@VPN scripts]# python day4-2.py
[6, 11, 13, 22, 99]

下面实现上节课的专业

一个配置文件需要实现以下三个功能

1,查找

2,添加

3,删除

配置文件ha

backend www.oldboy.org
server 100.1.7.9 100.1.7.9 weight
backend buy.oldboy.org
server 100.1.7.9 100.1.7.9 weight 20 maxconn 300
server 100.1.7.10 100.1.7.10 weight 20 maxcont 300
backend home.oldboy.org
server 100.1.7.9 100.1.7.9 weight 20 maxconn 300

vim day4-3.py

#!/usr/bin/python
# -*- coding:utf-8 -*-
def fetch(backend):
fetch_list = [] #定义一个空的列表用来放置对应的配置数据
with open('ha') as obj: #打开配置文件
flag = False #定义一个flag用于循环的判断
for line in obj: #一行行读取文件中的数据
if line.strip() == "backend %s" %backend: #如果匹配到backend +对应的参数
flag = True #把flag置为True
continue #结束本次循环
if flag and line.strip().startswith('backend'): #如果flag为True并且开始为backend结束整个循环
break #如果遇到下一个backend代表已经读取到了下一个配置文件了
if flag and line.strip(): #如果flag为真并且不是空行添加到fetch_list列表
fetch_list.append(line.strip())
return fetch_list #函数返回这个列表
result = fetch("buy.oldboy.org")
print (result)

  

下面实现添加

添加的格式为

s = '{"backup":"www.oldboy.org","record":{"server":"100.1.7.9","weight":20,"maxconn":30}}'

添加的步骤为

1,找到指定backend下所有记录

2,处理记录

原来存在该记录

原来不存在该记录

当原来配置文件不存在这条记录时

vim day4-4.py

#!/usr/bin/python
# -*- coding:utf-8 -*-
import json
import os
def fetch(backend):
fetch_list = [] #定义一个空的列表用来放置对应的配置数据
with open('ha') as obj: #打开配置文件
flag = False #定义一个flag用于循环的判断
for line in obj: #一行行读取文件中的数据
if line.strip() == "backend %s" %backend: #如果匹配到backend +对应的参数
flag = True #把flag置为True
continue #结束本次循环
if flag and line.strip().startswith('backend'): #如果flag为True并且开始为backend结束整个循环
break #如果遇到下一个backend代表已经读取到了下一个配置文件了
if flag and line.strip(): #如果flag为真并且不是空行添加到fetch_list列表
fetch_list.append(line.strip())
return fetch_list #函数返回这个列表
#result = fetch("buy.oldboy.org")
#print (result) def add1(dict_info):
backend_title = dict_info.get('backend')
#"backend www.oldboy.org"
current_title = "backend %s" %backend_title
current_record = "server %s %s weight %d maxconn %d" %(dict_info['record']['server'],dict_info['record']['server'],dict_info['record']['weight'],dict_info['record']['maxconn'])
#获取指定backend下面的所有记录
fetch_list = fetch(backend_title)
if fetch_list:
pass #存在backend,则只需再添加记录
else:
with open('ha','r') as read_obj,open('ha.new','w') as write_obj: #不存在backend,添加记录和backend
#把原配置文件中内容,写入新配置文件中
for line in read_obj:
write_obj.write(line)
write_obj.write("\n"+current_title+'\n')
temp = "%s%s\n" %(" "*8,current_record)
write_obj.write(temp)
s = '{"backend":"www.oldboy.org","record":{"server":"100.1.7.9","weight":20,"maxconn":30}}' #s是一个字符串
data_dict = json.loads(s) #使用json方法把字符串转换成字典
add1(data_dict)
os.rename("ha","ha.bak")
os.rename("ha.new","ha")

 执行结果会在原配置文件下面增加记录,记录的标题为www.oldboy.org内容为server 100.1.7.9 100.1.7.9 weight 20 maxconn 30

使用os模块的重命名功能把新生成的配置文件替换原来的配置文件,原来的配置文件做一个备份ha.bak

当原来配置文件存在这条记录标题时

如果插入的记录已经存在不插入,不存在则插入

vim day4-5.py

#!/usr/bin/python
# -*- coding:utf-8 -*-
import json
import os
def fetch(backend):
fetch_list = [] #定义一个空的列表用来放置对应的配置数据
with open('ha') as obj: #打开配置文件
flag = False #定义一个flag用于循环的判断
for line in obj: #一行行读取文件中的数据
if line.strip() == "backend %s" %backend: #如果匹配到backend +对应的参数
flag = True #把flag置为True
continue #结束本次循环
if flag and line.strip().startswith('backend'): #如果flag为True并且开始为backend结束整个循环
break #如果遇到下一个backend代表已经读取到了下一个配置文件了
if flag and line.strip(): #如果flag为真并且不是空行添加到fetch_list列表
fetch_list.append(line.strip())
return fetch_list #函数返回这个列表
#result = fetch("buy.oldboy.org")
#print (result) def add1(dict_info):
backend_title = dict_info.get('backend')
#"backend www.oldboy.org"
current_title = "backend %s" %backend_title
current_record = "server %s %s weight %d maxconn %d" %(dict_info['record']['server'],dict_info['record']['server'],dict_info['record']['weight'],dict_info['record']['maxconn'])
#获取指定backend下面的所有记录
fetch_list = fetch(backend_title)
if fetch_list: #存在backend,则只需再添加记录
if current_record in fetch_list:
pass #如果这条记录存在什么都不做
else:
fetch_list.append(current_record)#得到处理完之后的中间部分
#读配置文件,写新配置文件
#读上->新上
#新配置处理完之后配置文件写入新配置文件中
#读下->新下
flag = False
has_write = False
with open('ha','r') as read_obj,open('ha.new','w') as write_obj:
for line in read_obj:
if line.strip() == current_title:
flag = True
write_obj.write(line)#把backend写入到新配置文件里
continue
if flag and line.strip().startswith('backend'): #如果flag为True并且开始为backend结束整个循环
# write_obj.write(line)
flag = False
if flag and line.strip():
#把已经处理完的数据fetch_list写入到新配置文件中
if not has_write:
for new_line in fetch_list:
temp = "%s%s\n" %(" "*8,new_line)
write_obj.write(temp)
has_write = True
else:
write_obj.write(line)
else:
with open('ha','r') as read_obj,open('ha.new','w') as write_obj: #不存在backend,添加记录和backend
#把原配置文件中内容,写入新配置文件中
for line in read_obj:
write_obj.write(line)
write_obj.write("\n"+current_title+'\n')
temp = "%s%s\n" %(" "*8,current_record)
write_obj.write(temp)
s = '{"backend":"buy.oldboy.org","record":{"server":"100.1.7.39","weight":20,"maxconn":30}}' #s是一个字符串
data_dict = json.loads(s) #使用json方法把字符串转换成字典
add1(data_dict)
os.rename("ha","ha.bak")
os.rename("ha.new","ha")

  

Python冒泡算法和修改配置文件的更多相关文章

  1. python冒泡算法联系代码

    root@(none):~/python# python maopao.py[6, 11, 13, 22, 99]root@(none):~/python# cat maopao.py #!/usr/ ...

  2. python冒泡算法

    array = [1,2,3,6,5,4,28,2,1,9,3,0,200,2,9,3,2,98,33,988,22,0,223,0,33,78,222,88,32,0,238,883,2,0,23] ...

  3. python学习之路-6 冒泡算法、递归、反射、os/sys模块详解

    算法 冒泡算法 # 冒泡算法就是将需要排序的元素看作是一个个"气泡",最小的"气泡"最先浮出水面,排在最前面.从小到大依次排列. # 代码如下: li = [9 ...

  4. Python之collections序列迭代器下标式循环冒泡算法等

    练习题 元素分类 有如下值集合[11,22,33,44,55,66,77,88,99]将所有大于66的数作为一个列表放在字典的key为k1的value小于等于66的为k2的value {'k1':[7 ...

  5. Python系列之文件操作、冒泡算法、装饰器、及递归

    文件处理 python对文件进行读写操作的方法与具体步骤,包括打开文件.读取内容.写入文件.文件中的内容定位.及关闭文件释放资源等 open().file(),这个两函数提供了初始化输入\输出(I\O ...

  6. python查询修改配置文件功能

    阅读目录 一.python查询功能代码 1.查询修改配置文件 global log 127.0.0.1 local2 daemon maxconn 256 log 127.0.0.1 local2 i ...

  7. python读写修改配置文件(ini)

    python 有时候参数需要保存到配置文件中  接下来总结一下 配置文件的读写和修改的操作 代码如下: #!/usr/bin/env python # -*- coding: utf- -*- # 读 ...

  8. python排序算法实现(冒泡、选择、插入)

    python排序算法实现(冒泡.选择.插入) python 从小到大排序 1.冒泡排序: O(n2) s=[3,4,2,5,1,9] #count = 0 for i in range(len(s)) ...

  9. 44.python排序算法(冒泡+选择)

    一,冒泡排序: 是一种简单的排序算法.它重复地遍历要排序的数列,一次比较两个,如果他们的排序错误就把他们交换过来. 冒泡排序是稳定的(所谓稳定性就是两个相同的元素不会交换位置) 冒泡排序算法的运作如下 ...

随机推荐

  1. JS页面打开方式丶对话框及页面跳转方式

    一.js页面的三种打开方式 1. window.open 2. window.navigate("url") 跳转到目标页面 3. window.location.href=&qu ...

  2. 性能测试培训:sql server性能测试分析局部变量的性能影响

    poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.在poptest的loadrunner的培训中,为了提高学员性能优化的经验,加入了 ...

  3. 重写NSArray与NSDictionary的descriptionWithLocale方法

    重写NSArray的descriptionWithLocale方法: NSArray+log.h #import <Foundation/Foundation.h> @interface ...

  4. android 开机自启动实现

    App的开机自启动可以通过注册广播接收器接收开机广播来实现,具体步骤如下: 1.创建 BroadcastReceiver 的派生类,并重写 onReceive() 函数: /** * Created ...

  5. 《Python基础教程》第2章读书笔记(1)

    # -*- coding:utf-8 -*- #最基本的数据结构:序列,索引从0开始 #python包括6种内建的序列 #最常用的序列包括:列表,元祖 #列表 edward = ['Edward Gu ...

  6. Java ---自定义标签(二)

    上篇文章的最后,我们自定义了一个带属性的标签,并使用它完成了一个简单的案例.其实到这我们已经可以看出来,前端jsp页面只需要写一个类似html语法的标签,就可以完成将集合中的数据取出来并展示这么相对复 ...

  7. Java线程池(ThreadPool)详解

    线程五个状态(生命周期): 线程运行时间 假设一个服务器完成一项任务所需时间为:T1 创建线程时间,T2 在线程中执行任务的时间,T3 销毁线程时间.    如果:T1 + T3 远大于 T2,则可以 ...

  8. ABPZero中的Name和SurName处理

    使用ABPzero的朋友们都知道,User表中有Name和Surname两个字段,这两个字段对于国内的用户来说相当的不友好. 我们在尝试了很多的方法之后,发现无法完美将他们干掉. 所以尝试使用了一个比 ...

  9. 将linux的HOME目录下的文件夹名字改回英文

    为了使用起来方便,装了Ubuntu中文版,自然在home文件里用户目录的“桌面”.“图片”.“视频”.“音乐”……都是中文的.很多时候都喜欢在桌面上放一些要操作的文件,linux里命令行操作又多,难免 ...

  10. Spring+SpringMVC+MyBatis+easyUI整合优化篇(十一)数据层优化-druid监控及慢sql记录

    本文提要 前文也提到过druid不仅仅是一个连接池技术,因此在将整合druid到项目中后,这一篇文章将去介绍druid的其他特性和功能,作为一个辅助工具帮助提升项目的性能,本文的重点就是两个字:监控. ...