zoukankan      html  css  js  c++  java
  • 使用python脚本实现基于指定字符串的文本排序

    朋友用ansible导出了一个文件,文件中包含上千台机器的磁盘信息,他想要知道哪些机器最需要赶紧扩磁盘。思路是,按剩余磁盘空间百分数,从小到大对文本内容重新排序。下面是具体实现。

    源文件ip.txt的格式是这样的:

    10.1.2.1 224 | success | rc=0 >>
    /dev/sda1  1.1T  28G  982G  3%  /export
    
    10.1.2.1 24 | success | rc=0 >>
    /dev/sda2  1.6T  15G  1.5T  1%  /export

    下面是.py文件。运行这个python脚本后,可以生成ip_sorted.txt文件,是经过重排的文件,磁盘剩余空间越小,其机器信息会排在越前面。

    #!/bin/bash
    # -*- coding:utf-8 -*-
    
    import os
    import collections
    
    with open('ip.txt','r') as f:
        file_dic_ip = {}
        file_dic_info = {}
        i = 0
        for line in f:
            count = int(os.popen("grep -c '^/dev' ip.txt").read())
            while i < count:
                lines_ip = os.popen("grep -v '^/dev' ip.txt | grep -v '^$' ").read().split('
    ')
                lines_info = os.popen("grep -n '^/dev' ip.txt | awk -F ':' '{print $2}'").read().split('
    ')
                file_dic_ip[lines_info[i]] = lines_ip[i]
                lines_info_percent = os.popen("grep -n '^/dev' ip.txt | awk -F ' ' '{print $5}'").read().split('%
    ')
                file_dic_info[lines_info_percent[i]] = lines_info[i]
                i += 1
    
    od = collections.OrderedDict(sorted(file_dic_info.items()))
    with open('ip_sorted.txt','w') as f:
        for items in od.items():
            f.write(file_dic_ip[items[1]] + '
    ' + items[1] + '
    
    ')

    流程图不太对,将就看看文字讲解吧

  • 相关阅读:
    sklearn KMeans聚类算法(总结)
    求素数的一个快速算法 Python 快速输出素数算法
    Java方法的多态
    Java static特性
    第一周-调用weka算法进行数据挖掘
    第一周 -神经网络算法与实现
    1【西北师大-2108Java】第一次作业成绩汇总
    第一周博客作业
    十一,专著研读(CART算法)
    十,专著研读(线性回归)
  • 原文地址:https://www.cnblogs.com/huamingao/p/5766788.html
Copyright © 2011-2022 走看看