zoukankan      html  css  js  c++  java
  • 文件操作的补充

    1.原始文件

    global
            log 127.0.0.1 local2
            daemon
            maxconn 256
            log 127.0.0.1 local2 info
    defaults
            log global
            mode http
            timeout connect 5000ms
            timeout client 50000ms
            timeout server 50000ms
            option  dontlognull
    
    listen stats :8888
            stats enable
            stats uri       /admin
            stats auth      admin:1234
    
    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.oldboy.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 3000
            server 100.1.7.7 100.1.7.6 weight 20 maxconn 3000
    backend ccc.oldboy.org
            server 100.1.7.9 100.1.7.9 weight 20 maxconn 300
    

    2.操作要求:

    3.思路分析

    1)一行一行读取,遇到第一个backend做标记,把下面内容加入列表,遇到第二个backend停止添加。

    2)思路一:把内容添加进列表,然后把列表内容写入。

        思路二:读一行,写一行,直到写到第二个backend,再此之前插入内容即可。

    4.代码实现:

    1)

    def chaxun(a):
        l1=[]
        title='backend %s' % a
        with open('mm','r')as f1:
            flag=False #默认没找到标题
            for line in f1:
                line=line.strip()
                if line==title:
                    flag=True  #找到标题
                    continue
                if flag and line.startswith('backend'):
                    flag = False  #标题结束
                    break
                if flag and line:  #找到标题且不是空行
                    l1.append(line)
        return l1
    

      思路一:

    # a=input('请输入网址:')
    # a='www.oldboy.org'
    
    # b=input('请输入新纪录字典:')
    b='{"backend":"www.oldboy.org","record":{"server":"100.1.7.6","weight":20,"maxconn":30}}'
    b=json.loads(b)
    a=b["backend"]
    s=b["record"]
    s="server %s %s weight %s maxconn %s" % (s['server'],s['server'],s['weight'],s['maxconn'])
    title='backend %s' % a
    l1=chaxun(a)
    l1.append(s)
    print(l1)
    with open('mm') as read_obj, open('nn', 'w') as write_obj:
        flag = False      #默认没有找到目标标题
        has_write = False  #默认列表内容还没有写
        for line in read_obj:
            if line.strip() == title:
                write_obj.write(line)
                flag = True  #找到标题
                continue
            if flag and line.strip().startswith('backend'):
                flag = False  #标题结束
            if flag:   #如果已经找到目标标题
                if not has_write: #如果还没有写内容
                    for new_line  in l1:
                        temp = "%s %s 
    " %(" "*8, new_line)
                        write_obj.write(temp)
                    has_write = True
                    #列表内容书写完毕,即使flag=True,即使没遇到下一个backend,也不会书写内容
            else:
        # 写入上下部分
                write_obj.write(line)
    

      思路二:

    # a=input('请输入网址:')
    # a='www.oldboy.org'
    
    # b=input('请输入新纪录字典:')
    b='{"backend":"www.oldboy.org","record":{"server":"100.1.7.6","weight":20,"maxconn":30}}'
    b=json.loads(b)
    a=b["backend"]
    s=b["record"]
    s="server %s %s weight %s maxconn %s" % (s['server'],s['server'],s['weight'],s['maxconn'])
    title='backend %s' % a
    l1=chaxun(a)
    l1.append(s)
    print(l1)
    with open('mm') as read_obj, open('nn', 'w') as write_obj:
        flag = False      #默认没有找到目标标题
        for line in read_obj:
            if line.strip() == title:
                write_obj.write(line)
                flag = True  #找到标题
                continue
            if flag and line.strip().startswith('backend'):
                write_obj.write("%s%s 
    " %(" "*8, s))
                write_obj.write(line)
                flag = False  #标题结束
            else:
        # 写入上下部分
                write_obj.write(line)
    

      

  • 相关阅读:
    Spyder汉化问题
    Python配置环境变量
    Python、Spyder的环境搭建
    自然语言处理(六)词向量
    自然语言处理(五)深度学习
    自然语言处理(三)主题模型
    自然语言处理(四)统计机器翻译SMT
    自然语言处理(二) 语言模型
    自然语言处理(一)基础知识
    机器学习(九)隐马尔可夫模型HMM
  • 原文地址:https://www.cnblogs.com/wanghzh/p/5543474.html
Copyright © 2011-2022 走看看