python基礎:day3作業

来源:http://www.cnblogs.com/alan-babyblog/archive/2016/02/04/5181156.html
-Advertisement-
Play Games

修改haproxy配置文件 基本功能:1.獲取記錄2.添加記錄3.刪除記錄 代碼結構:三個函數一個主函數 知識點:1.python簡單數據結構的使用:列表、字典等 2.python兩個模塊的使用:os和json a.os.rename('文件1','文件2') b.json完成自動識別字典、列表,並


修改haproxy配置文件

基本功能:
1.獲取記錄
2.添加記錄
3.刪除記錄

代碼結構:
三個函數一個主函數

知識點:
1.python簡單數據結構的使用:列表、字典等

2.python兩個模塊的使用:os和json

      a.os.rename('文件1','文件2')

      b.json完成自動識別字典、列表,並識別後進行自動轉換

3.python函數的定義和調用

4.標誌位的靈活運用:flag和haswrite分別用於找backend的record和判斷是否已經將記錄寫入到文件

5.python基本語法的使用:for迴圈、if...else....判斷

6.python文件的操作的基本使用:with open('文件1','模式') as obj1,open('文件2','模式') as obj2

 

流程圖:

代碼:

#!/usr/bin/env python3

#antuor:Alan
import os
import json

"""
把文件按從上到下的順序分為上部分,要處理部分,下部分;
step1: 上部分從原配置文件寫入-->新配置文件
step2: 遇到要處理部分則寫入-->fetch_list
step3: 下部分從原配置文件寫入-->新配置文件
step4:  fetch_list入-->新配置文件
"""


def fetch(backend):                            ###定義fetch函數,並同時傳入我們指定backend參數,此參數代表backend名
    flag = False                               ###定義flag為False,目的是為了後面是否取可用的backend
    fetch_list=[]                              ###定義空列表,目的是為了後面將取出的backend信息存儲在此列表裡面
    with open('配置文件.txt') as obj:           ###打開配置文件
        for line in obj:                       ###一行行讀取
            if line.strip() == "backend %s" %(backend):   ###line.stri()去掉空格和換行符
                flag = True                    ###讀到要取的記錄flage改為True
                continue                       ###結束本次迴圈,下麵代碼不執行,開始新的迴圈
            if flag and line.strip().startswith('backend'):  ###如果已經取到記錄,則又讀到backend開頭的數據則不取
                flag=False
            if flag and line.strip():          ###判斷flag為True,且不是空行(布爾值非空是True)
                fetch_list.append(line.strip())  ###把數據加入列表

    return fetch_list                          ###返回值



def add1(dict_info):                           ###定義add1函數,同時傳入參數dict_info,字典參數裡面包含要傳入的server信息
    backend_title = dict_info.get("backend")   ###插入的backend的名稱(變數初始化)
    context_title = "backend %s" %(backend_title)  ###插入backend整個欄位(變數初始化)
    record_title = dict_info["record"]         ###要插入的記錄(變數初始化)
    context_record = "server %s %s weight %s maxconn %s" %(record_title["server"],record_title["server"],record_title["weight"],record_title["maxconn"])
    fetch_list=fetch(backend_title)            ###把讀取的記錄放入列表(變數初始化)


    if fetch_list:                            ###判斷列表是否為空
        flag=False                            ###標誌位
        has_write = False                     ###標誌位
        with open('配置文件.txt','r') as read_obj,open('新配置文件.txt','w') as write_obj:
            for line in read_obj:
                if line.strip() == context_title:
                    write_obj.write("\n"+line)
                    flag=True
                    continue
                if flag and line.startswith('backend'):       ###flag為True,如果在讀到backend信息,則不處理
                    flag = False
                if flag:
                    for new_line in fetch_list:
                        if not has_write:
                            temp = "%s%s" %(" "*8,new_line)   ###把列表的記錄賦值給temp
                            write_obj.write(temp)
                            has_write=True
                else:
                    write_obj.write(line)


    else:                                                     ###如果fetch_list為空
        with open('配置文件.txt') as read_obj,open('新配置文件.txt','w') as write_obj:
            for line in read_obj:
                write_obj.write(line)
            write_obj.write("\n"+context_title+"\n")
            temp=" "*8+context_record+"\n"
            write_obj.write(temp)


    os.rename('配置文件.txt','配置文件.txt')                  ###將原文件配置文件改名備用文件為配置文件b
    os.rename('新配置文件.txt','配置文件.txt')                 ###將新配置文件改名為配置文件



def delete(dict_info):                                      ###刪除函數

    del_backend = dict_info["backend"]
    del_record = dict_info["record"]

    context_title = "backend %s" %(del_backend)
    context_record = "server %s %s weight %s maxconn %s" %(del_record["server"],del_record["server"],del_record["weight"],del_record["maxconn"])


    fetch_list = fetch(del_backend)

    if not fetch_list:
        return

    else:

        if context_record not in fetch_list:
            print ("your server message is not exists")
            return

        else:
            fetch_list.remove(context_record)

        with open('配置文件.txt','r') as read_obj,open('新配置文件.txt','w') as write_obj:
            flag = False
            has_write = False
            for line in read_obj:
                if line.strip() == context_title:
                    write_obj.write(line)
                    flag = True
                    continue
                if flag and line.startswith('backend'):
                    flag = False
                if flag:
                    if not has_write:
                        print (fetch_list)
                        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)


    os.rename('配置文件.txt','配置文件.txt')
    os.rename('新配置文件.txt','配置文件.txt')



s='{"backend":"ttt.oldboy.org","record":{"server":"100.1.7.9","weight":"20","maxconn":"3000"}}' ###要添加的記錄信息


if __name__ == "__main__":                                      ###主函數,入口

    print (u"1.獲取記錄\n2.添加記錄\n3.刪除記錄\n")                ###獲取用戶的操作選擇
    select_num=input("請輸入需要進行的操作編號:")

    if select_num == "1":                                       ###根據用戶的選擇,進行調用函數
        backend = input("請輸入backend信息:")
        fetch_list = fetch(backend)
        for i in fetch_list:
            print ("配置信息:%s" % i)
    else:
        print ("請按以下格式輸入:")
        print ('{"backend":"ttt.oldboy.org","record":{"server":"100.1.7.9","weight":"20","maxconn":"3000"}}')
        data_str = input("請輸入信息>>>")
        data_dict = json.loads(data_str)
        if select_num == "2":
            add1(data_dict)
        elif select_num == "3":
            delete(data_dict)
        else:
            print ("輸入有誤!!!!!")

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用SmtpClient發送Email時,我們可以創建ISmtpClient介面和SmtpClientWrapper適配類,在單元測試中對ISmtpClient進行Mock或自定義FackeSmtpClient,但nDumbster的Facke SMTP Server給我們提供了更直觀更簡單的方式進
  • 最近在做微信開發時用到了一些json的問題,就是把微信返回回來的一些json數據做一些處理,但是之前json掌握的不好,浪費了好多時間在查找一些json有關的轉換問題,我所知道的方法只有把json序列化和反序列化一下,但是太麻煩了我覺得,所以就在找一些更簡單又方便使用的方法。也許這個會有用吧,所以先
  • ASP.NET 上下文對象 ASP.NET 提供了一系列對象用來給當前請求,將要返回到客戶端的響應,以及 Web 應用本身提供上下文信息。間接的,這些上下文對象也可以用來回去核心 ASP.NET 框架特性。 上下文對象提供了應用,當前請求,與當前請求相關聯的響應的信息。也提供了對多數重要的 ASP.
  • 註:本文是【ASP.NET Identity系列教程】的第二篇。本系列教程詳細、完整、深入地介紹了微軟的ASP.NET Identity技術,描述瞭如何運用ASP.NET Identity實現應用程式的用戶管理,以及實現應用程式的認證與授權等相關技術,譯者希望本系列教程能成為掌握ASP.NET Id
  • 一、修改數據 其實修改涉及的內容挺多的,是相對於其他操作來說比較繁瑣。也是本文的重頭戲。 雖然都是基礎內容,但是也是值得細細品味的。 1、最簡單直接的修改數據就是從資料庫里檢索出數據修改相應的欄位即可 數據表: Code: using (var db = new ApplicationDbConte
  • 有時候我們需要編寫一些迎合IOS用戶使用習慣的uwp應用,我在這裡整理一下仿IOS頁面切換效果的代碼。 先分析IOS的頁面切換。用戶使用左右滑動方式進行前進和後退,播放類似於FlipView的切換動畫。導航到新頁面時,使用頁面前進的動畫。 UWP自帶很多切換效果,位於 Windows.UI.Xaml...
  • 當我們向GlobalConfiguration.Configuration.MessageHandlers添加一個DelegatingHandler派生類後,很容易發生即使命中了Action,但方法參數值為null的問題。
  • 在文章《Python程式員從小白到大神必讀資料彙總(一)到(三)》裡面介紹了基礎學習資料和一點點的進階資料,今天小編收集了5篇帶有實例乾貨的資料,趕緊來看看吧!另外,喜歡寫博客的博主可以申請加工程師博主交流群:391519124,分享你的博文,和大牛們一起交流技術~ 一、GitHub上有趣的pyth
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...