python - 文件-京东面试ip取前十

京东二面编程题
#1. 生成一个大文件ips.txt,要求1200行, 每行随机为172.25.254.0/24段的ip;
#2. 读取ips.txt文件统计这个文件中ip出现频率排前10的ip;

import random
def creat_ip_file(filename):
    ips = ['172.25.254.'+str(i) for i in range(0,255)]
    print(ips)
    with open(filename,'a+') as f:
        for count in range(1200):
            f.write(random.sample(ips,1)[0]+'\n')   # random.sample返回的是列表

def sorted_ip(filename,count=10):
    ips_dict = dict()
    with open(filename) as f:
        for ip in f:    # 文件内容也可以遍历
            if ip in ips_dict:
                ips_dict[ip] += 1
            else:
                ips_dict[ip] =1
    print(ips_dict.items())
    sorte_ip = sorted(ips_dict.items(),key=lambda
        x:x[1],reverse=True)[:count]    # 匿名函数按照字典里第二个函数的大小 从大到小排序
                                        # 因为是一个列表,所以只要从第1个到第10个
    return sorte_ip

creat_ip_file('ips.txt')
print(sorted_ip('ips.txt'))

ips.txt文件
python - 文件-京东面试ip取前十
前十:
python - 文件-京东面试ip取前十

一点关于sorted的补充:

#对于字典里面嵌套字典进行排序
d = {
    '003':{
        'name':'apple1',
        'count':100,
        'price':10
    },
    '002':{
        'name':'apple2',
        'count':200,
        'price':2
    }

}

sort = sorted(d.items() ,key = lambda x: x[1]['count'],reverse = True)
print(sort)
 #x:('003', {'name': 'apple1', 'count': 100, 'price': 10})
# print(sorted(d.items(),key=lambda x:x[1]['count']))	按照count排序
# print(sorted(d.items(),key=lambda x:x[1]['price']))	按照price排序

python - 文件-京东面试ip取前十