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文件
前十:
一点关于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排序