ha.txt文件内容:

frontend oldboy.org
bind 0.0.0.0:80
option httplog
option httpclose
option forwardfor
log global
acl www hdr_reg(host) -i www.oldboy.org
use_backend www.oldboy.org if www backend www.baidu.org
server 100.1.7.9 100.1.7.9 weight 20 maxconn 3000
server 100.1.7.8 100.1.7.8 weight 20 maxconn 4000
backend www.baidu1.com
server 1.1.1.1 1.1.1.1 weight 20 maxconn 3000

操作代码ha.py:

import os
#查询
def fetch(data):
# 把整行作为一个整体,做成字符串拼接
# 相当于拼接backend www.baidu.com
#record存放返回的数据
backend_data = "backend %s" %data
record_list = [] #定义空列表
#打开文件
with open('ha.txt','r',encoding='utf8') as f:
#在报警期间,一直执行捕捉操作
tag = False#报警器,默认不响
for line in f: #查找backend记录
#找backend,比较的时候把\n去掉,用sttrip实现
if line.strip() == backend_data:#找到这行,在去除回车之后,是否等于backend
tag = True#警报响起
continue#backend这行不要,跳出本次循环,下次循环都要带着tag警报了
# 解除警报
# 警报亮着,并且满足再次匹配backend的时候
#警报不能放到最后,在抓最后一个人之前,要把警报关闭
if tag and line.startswith("backend"):
#tag = False # 解除警报,但是break之后什么变量都不生效了
break
#当tag=True的情况
#警报亮了,并且有数据进来。line在文件中可能是空行,再加一个and操作
if tag and line:
record_list.append(line.strip())#添加数据,每添加一行数据,就循环一次 #打印用户找到的信息
for line in record_list:
print(line)
return record_list#返回处理的信息 #添加
def add(data):
backend = data['backend']#获取
record_list = fetch(backend)#传递给fetch
#把用户输入的字典转换成server的模式
current_record = "server %s %s weight %s maxconn %s" %(data['record']['server'], \
data['record']['server'], \
data['record']['weight'], \
data['record']['maxconn']) backend_data = "backend %s" %backend#拼接字符串 #record_list为空的情况下,运行下面的代码
if not record_list:
#加入record里面
record_list.append(backend_data)#标题
record_list.append(current_record)#server记录
#打开源文件,打开新文件把源文件内容一行行写入新文件
with open("ha.txt",'r',encoding="utf-8") as read_file,\
open("ha_new.txt",'w',encoding='utf-8') as write_file:
#从源文件一行行读取内容
for r_line in read_file:
write_file.write(r_line)#新文件一行行写 #用户输入的内容
for new_line in record_list:#读
if new_line.startswith('backend'):#是backend开头的文件
write_file.write(new_line + '\n')#往新文件里写
else:#其余行
write_file.write("%s%s\n" %(" "*8,new_line))#8个空格,写
else:
#print(record_list)
#自己创造一个record_list,把添加的server添加进去,保留原记录
record_list.insert(0,backend_data)
if current_record not in record_list:#
record_list.append(current_record)#添加自己拼接的记录
#print("new record list %s" %record_list)#新拼接的列表
with open('ha.txt','r',encoding='utf-8') as read_file,\
open('ha_new.txt','w',encoding='utf-8') as write_file:
#警报
tag = False
has_write = False
for r_line in read_file:#源文件读
if r_line.strip() == backend_data:#拉响警报
tag = True
continue
#如果警报是响的并且是匹配到backend的情况
if r_line.strip() == backend_data:
tag = True
continue if not tag:#警报没有响
write_file.write(r_line)#一直往新文件里写
else:#警报响
if not has_write:#如果没有写的情况
for new_line in record_list:
if new_line.startswith('backend'):
write_file.write(new_line + '\n')
else:
write_file.write('%s%s\n' %(' '*8,new_line))
has_write = True#record_list不会写
os.rename('ha.txt','ha_bak.txt')
os.rename('ha_new.txt','ha.txt')
os.remove('ha_bak.txt')
#删除
def remove(data):
backend = data['backend']
record_list = fetch(backend)#查
current_record = "server %s %s weight %s maxconn %s" % (data['record']['server'],\
data['record']['server'],\
data['record']['weight'],\
data['record']['maxconn']) backend_data = "backend %s" % backend
#为空
if not record_list or current_record not in record_list:
print("\033[33;1m无此条记录\033[0m")
return #终止掉
else:
#处理record_list,存在,统一处理
record_list.insert(0,backend_data)#标题加进去
record_list.remove(current_record)#把用户删除的列表删掉
with open('ha.txt','r',encoding='utf-8') as read_file,\
open('ha_new.txt','w',encoding='utf-8') as write_file:
tag = False
has_write = False
for r_line in read_file:
if r_line.strip() == backend_data:
tag = True
continue
if tag and r_line.startswith('backend'):
tag = False
if not tag:
write_file.write(r_line)
else:
if not has_write:
for new_line in record_list:
if new_line.startswith('backend'):
write_file.write(new_line + '\n')
else:
write_file.write('%s%s\n' %(' '*8,new_line))
has_write = True
os.rename('ha.txt','ha_bak.txt')
os.rename('ha_new.txt','ha.txt')
os.remove('ha_bak.txt') def change(data):
#通过列表找到backend信息
backend = data[0]['backend']
record_list = fetch(backend)#找到backend信息 #改的数据,旧内容,新内容
old_record = "server %s %s weight %s maxconn %s" % (data[0]['record']['server'], \
data[0]['record']['server'], \
data[0]['record']['weight'], \
data[0]['record']['maxconn']) new_record = "server %s %s weight %s maxconn %s" % (data[1]['record']['server'], \
data[1]['record']['server'], \
data[1]['record']['weight'], \
data[1]['record']['maxconn']) backend_data = "backend %s" % backend #没有backend或者server信息不存在
if not record_list or old_record not in record_list:
print('\033[33;1m无此内容\033[0m')
return
else:
record_list.insert(0,backend_data)#重新生成record_list
index=record_list.index(old_record)#旧内容索引
record_list[index]=new_record#替换
with open('ha.txt', 'r', encoding='utf-8') as read_file, \
open('ha_new.txt', 'w', encoding='utf-8') as write_file:
tag = False
has_write = False
for r_line in read_file:
if r_line.strip() == backend_data:
tag = True
continue
if tag and r_line.startswith('backend'):
tag = False
if not tag:
write_file.write(r_line)
else:
if not has_write:
for new_line in record_list:
if new_line.startswith('backend'):
write_file.write(new_line + '\n')
else:
write_file.write('%s%s\n' % (' ' * 8, new_line))
has_write = True
os.rename('ha.txt', 'ha_bak.txt')
os.rename('ha_new.txt', 'ha.txt')
os.remove('ha_bak.txt') #代码运行的时候就会把__name__赋值给__main__
#如果把代码当做模块导入,__name__就会被赋值为文件名
if __name__ == '__main__':#系统内置变量
#用户提示信息
msg = '''
1:查询-fetch
2:添加-add
3:删除-remove
4:修改-change
5:退出-exit
'''
#定义字典,实现提示信息与上面函数的对应关系,数字:函数名,不能加(),加上就是运行结果
#key定义成字符串的形式
menu_dic = {
'1':fetch,
'2':add,
'3':remove,
'4':change,
'5':exit
}
#死循环,不断的跟用户去交互
#主逻辑
while True:
print(msg)
choice=input("操作>>:").strip()#用户选择
if choice == '2' or choice == '3':
print("实例:{'backend':'www.baidu1.com','record':{'server':'2.2.2.2','weight':20,'maxconn':3000}}")
if choice == '4':
print("实例(旧内容,新内容):[{'backend':'www.baidu1.com','record':{'server':'1.1.1.1','weight':20,'maxconn':3000}},{'backend':'www.baidu1.com','record':{'server':'2.2.2.2','weight':20,'maxconn':4000}}]")
#用户为空 or 用户超过可选范围
if len(choice) == 0 or choice not in menu_dic:continue#不在里面
if choice == '5':break #在用户输入完操作选项之后,输入
#data输入完之后,要把数据传入到上面的一个个功能,就是在函数名的地方加上data
#所以上面的所有函数都要有参数,在函数名的()内都要加上data #用户输入的是字典的话,转换成字符串赋值给data
data = input("数据>>:").strip() #如果用户输入不是1查询的话,因为默认是字符串的模式,所以要加引号
if choice != '1':
#在下面执行的时候,再通过eval转换成字典,最后赋值给add,或者del功能
data = eval(data)#把用户输入的字符串转换成字符串原本包含的格式,最终赋值给data #用户执行操作
#menu_dic[choice]==fetch
#menu_dic[choice]() == fetch()
# menu_dic[choice](data) == fetch(data)
#定义一个字典,通过字典的方式调用一个函数,这样函数名有变动,只要改字典的对应关系就可以了,这样主逻辑就不用动了
menu_dic[choice](data)

python处理ha文件的更多相关文章

  1. Python基础之文件处理、函数、内置函数 (三)

    内置函数 一 详细见python文档,请点击 文件操作 操作文件时,一般需要经历如下步骤: 打开文件 操作文件 一.打开文件 文件句柄 = file('文件路径', '模式') 注:python中打开 ...

  2. python基础之文件处理

    读和写文件 读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直 ...

  3. Python开发【第三篇】:Python基本之文件操作

    Python基本之文本操作 一.初识文本的基本操作 在python中打开文件有两种方式,即:open(...) 和  file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open ...

  4. Python绘制PDF文件~超简单的小程序

    Python绘制PDF文件 项目简介 这次项目很简单,本次项目课,代码不超过40行,主要是使用 urllib和reportlab模块,来生成一个pdf文件. reportlab官方文档 http:// ...

  5. python基础之文件读写

    python基础之文件读写 本节内容 os模块中文件以及目录的一些方法 文件的操作 目录的操作 1.os模块中文件以及目录的一些方法 python操作文件以及目录可以使用os模块的一些方法如下: 得到 ...

  6. python批量进行文件修改操作

    python批量修改文件扩展名 在网上下载了一些文件,因为某种原因,扩展名多了一个后缀'.xxx',手动修改的话因为文件太多,改起来费时费力,于是决定写个小脚本进行修改. 1.要点: import r ...

  7. 关于Python中的文件操作(转)

    总是记不住API.昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧: python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Pyth ...

  8. Python基础、文件处理

    一.概述 Python中操作文件是通过file对象来处理的,步骤: 指定文件的路径.操作的模式 对文件进行操作,读或写操作 关闭文件对象 f = open( '文件路径','访问模式') # 打开文件 ...

  9. python os&shutil 文件操作

    python os&shutil 文件操作 # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\' os.name 字符串指示你正在使用的平台.比如对于W ...

随机推荐

  1. Atitti 文本分类  以及 垃圾邮件 判断原理 以及贝叶斯算法的应用解决方案

    Atitti 文本分类  以及 垃圾邮件 判断原理 以及贝叶斯算法的应用解决方案 1.1. 七.什么是贝叶斯过滤器?1 1.2. 八.建立历史资料库2 1.3. 十.联合概率的计算3 1.4. 十一. ...

  2. fir.im Weekly - 这是一份强大的 SwiftGuide

    大新闻!Apple 10 亿美元融资滴滴!库克大叔对中国 iOS 开发者表达了高度认可,同时也传出 iOS 10 将内置滴滴 App 的消息.想像下,某个加班的深夜飙完代码,最性感的事情莫过于:「Si ...

  3. fir.im Weekly - iOS 保持界面流畅的技巧

    生命不息,coding 不止.本期 fir.im Weekly 收集了微博上的热转资源,包含 Android.iOS 开发工具.源码分享,产品 UI 设计的好文章,还有一些程序员成长的 Tips,希望 ...

  4. 利用奇异值分解(SVD)简化数据

    特征值与特征向量 下面这部分内容摘自:强大的矩阵奇异值分解(SVD)及其应用 特征值分解和奇异值分解在机器学习领域都是属于满地可见的方法.两者有着很紧密的关系,在接下来会谈到,特征值分解和奇异值分解的 ...

  5. 最简单的SVN环境搭建过程

    本文简单描述最简单的SVN环境搭建过程 搭建环境:windows (个人验证了windows2003,windows xp) 使用软件:Setup-Subversion-1.6.17  //Serve ...

  6. maven项目部署打包

    方法一.把maven依赖的jar包一起打包 http://maven.apache.org/plugins/maven-assembly-plugin/usage.html pom/build中加入以 ...

  7. javascript运算符——条件、逗号、赋值、()和void运算符

    × 目录 [1]条件 [2]逗号 [3]赋值[4]()[5]void 前面的话 javascript中运算符总共有46个,除了前面已经介绍过的算术运算符.关系运算符.位运算符.逻辑运算符之外,还有很多 ...

  8. Example of BeanFactoryAware in Spring--转

    原文地址:http://www.concretepage.com/spring/example_beanfactoryaware_spring If a bean in spring implemen ...

  9. [转载]基于TFS实践敏捷-工作项跟踪

    工作项跟踪(1) 可跟踪性是软件过程的重要能力,TFS主要是以工作项来实现过程的可跟踪性.曾有人问:"你们实际项目里的工作项是怎么样的?能不能让我们看看?"我也一直很好奇别的公司T ...

  10. [SDK2.2]Windows Azure Virtual Network (4) 创建Web Server 001并添加至Virtual Network

    <Windows Azure Platform 系列文章目录> 在上一章内容中,笔者已经介绍了以下两个内容: 1.创建Virtual Network,并且设置了IP range 2.创建A ...