1.如果同一个ip地址60s之内访问超过200次,那么就把ip加入黑名单

需求分析:

1.60s读一次文件

2.分割,取第一个元素,ip地址

3.把所有ip加入到一个list里面,如果ip次数超过200次加入黑名单

import time

point = 0 # 文件指针

while True:

blk_set = set() # 定义空集合,存放需要加入黑名单的ip

ips = [] # 存放所有ip地址

with open('access.log') as f:

f.seek(point)

for line in f:

ip = line.split()[0]

ips.append(ip)

if ips.count(ip) > 200:

blk_set.add(ip)

for ip in blk_set: # 去重

print('已把%s加入黑名单' % ip)

point = f.tell()

time.sleep(60)

2.判断是否为小数

# 小数点的个数,小数点的个数是否等于1

# 按照小数点分割

def check_float(s):

s = str(s)

if s.count('.') == 1:

s_list = s.split('.')

# 1.2 [1, 2]

# -5.3 [-5, 4]

left = s_list[0]

right = s_list[1]

if left.isdigit() and right.isdigit(): # 正小数

return True

elif left.startswith('-') and left.count('-') == 1: # 负小数

if left.split('-')[-1].isdigit() and right.isdigit():

return True

return False

3.对比字典内容

dict1 = {

"version": "9.0.0",

"is_test": True,

"store": "",

"urs": "",

"device": {

"os": "android",

"ime1": "99001062198893",

"device_id": "CQliMWEyYTEzNTYyYzk5MzJmCTJlNmY3Zjkx",

"mac": "02:00:00:00:00:00",

"galaxy_tag": "CQliMWEyYTEzNTYyYzk5MzJmCTJlNmY3Zjkx",

"udid": "a34b1f67dd5797df93fdd8b072f1fb8110fd0db6",

"network_status": "wifi"

},

"adunit": {

"category": "VIDEO",

"location": "1",

"app": "7A16FBB6",

"blacklist": ""

},

"ext_param": {

"is_start": 0,

"vId": "VW0BRMTEV"

}

}

dict2 = {

"version": "9.0.0",

"is_test": True,

"urs": "",

"store": "",

"device": {

"os": "android",

"imei": "99001062298893",

"device_id": "CQliMWEyYTEzNTYyYzk5MzJmCTJlNmY3Zjkx",

"mac": "02:00:00:00:00:00",

"galaxy_tag": "CQliMWEyYTEzNTYyYzk5MzJmCTJlNmY3Zjkx",

"udid": "a34b1f67dd5797da93fdd8b072f1fb8110fd0db6",

"network_status": "wifi"

},

"adunit": {

"category": "VIDEO",

"location": "1",

"app": "7A16FBB6",

"blacklist": ""

}, "ext_param": {

"is_start": 0,

"vid": "VW0BRMTEV"

}

}

# 判断两个字典里面不一样的key,value

# 只需判断d1里面有

# 循环d1,通过key去d2里面取值

# 判断通过key取到的类型是什么,如果是字典的话,继续循环

# 然后再判断key和value

def compare(d1, d2):

for key in d1:

value1 = d1.get(key)

value2 = d2.get(key, '不存在')

if type(value1) == dict:

compare(value1, value2)

else:

if value1 != value2 and value2 == '不存在':

print('value不一样的key:%s,value1:%s,value2:%s' % (key, value1, value2))

res = set(d1.keys()).symmetric_difference(set(d2.keys())) # 对称差集,两个字典里面不一样的key

if res:

print('key不一样的是', ','.join(res))

compare(dict1, dict2)

Python 小练习一的更多相关文章

  1. Python小工具--删除svn文件

    有的时候我们需要删除项目下的svn相关文件,但是SVN会在所有的目录下都创建隐藏文件.svn,手工一个个目录查找然后删除显然比较麻烦.所以这里提供了一个Python小工具用于批量删除svn的相关文件: ...

  2. python小练习(自己瞎倒腾)

    python小练习 在网上无意中看到一个问题,心血来潮写了写,觉得比较有意思,以后遇到这种有意思的小练习也记录下. #!/usr/bin/env python # -*- coding:utf-8 - ...

  3. python小练习之二

    title: python小练习之二 tags: 新建,模板,小书匠 grammar_cjkRuby: true --- python小练习之二 需求:实现用户登录,用户名和密码保存到文件里,连续输入 ...

  4. Python小代码_2_格式化输出

    Python小代码_2_格式化输出 name = input("name:") age = input("age:") job = input("jo ...

  5. Python小代码_1_九九乘法表

    Python小代码_1_九九乘法表 max_num = 9 row = 1 while row <= max_num: col = 1 while col <= row: print(st ...

  6. python小练习---TCP服务器端

    针对于上一篇分享python小练习---TCP客户端 http://www.cnblogs.com/zhaijiahui/p/6926197.html我继续按书中内容,向下进行这里需要强调一个事py3 ...

  7. python小练习:使用循环和函数实现一个摇骰子小游戏。游戏规则如下:游戏开始,首先玩家选择Big or Small(押大小),选择完成后开始摇三个骰子,计算总值,11<=总值<=18为“大”,3<=总值<=10为“小”。然后告诉玩家猜对或者是猜错的结果。

    python小练习:使用循环和函数实现一个摇骰子小游戏.游戏规则如下:游戏开始,首先玩家选择Big or Small(押大小),选择完成后开始摇三个骰子,计算总值,11<=总值<=18为“ ...

  8. python小练习1:设计这样一个函数,在桌面的文件夹上创建10个文本,以数字给它们命名。

    python小练习1:设计这样一个函数,在桌面的文件夹上创建10个文本,以数字给它们命名. 使用for循环即可实现: for name in range(1,11): desktop_path='C: ...

  9. python小工具myqr生成动态二维码

    python小工具myqr生成动态二维码 (一)安装 (二)使用 (一)安装 命令: pip install myqr 安装完成后,就可以在命令行中输入 myqr 查看下使用帮助: myqr --he ...

  10. Python小数据池,代码块

    今日内容一些小的干货 一. id is == 二. 代码块 三. 小数据池 四. 总结 python小数据池,代码块的最详细.深入剖析   一. id is == 二. 代码块 三. 小数据池 四. ...

随机推荐

  1. 第七次scrum meeting记录

    文章负责:张华杰 日期:2017年10月31日 会议地点:主楼主南201 各组员工作情况 团队成员 昨日完成任务 明日要完成任务 赵晓宇 课程列表页面搭建 issue20 课程列表页面搭建(part ...

  2. sqlserver数据库脱机时发生异常:由于无法在数据库 'SMS' 上放置锁,ALTER DATABASE 失败。请稍后再试。 ALTER DATABASE 语句失败。 (.Net SqlClient Data Provider)

    sqlserver数据库脱机时发生异常,如下: =================================== 设置脱机 对于 数据库“SMS”失败.  (Microsoft.SqlServe ...

  3. 【tensorflow:Google】三、tensorflow入门

    [一]计算图模型 节点是计算,边是数据流, a = tf.constant( [1., 2.] )定义的是节点,节点有属性 a.graph 取得默认计算图 g1 = tf.get_default_gr ...

  4. windows获取屏幕显示比例 读取注册表法

    static int GetDesktopScale() { ; HINSTANCE hUser32 = LoadLibrary(L"user32.dll"); if (hUser ...

  5. 实战JAVA 高并发设计

    一.同步(Synchronous)和异步(Asynchronous) 同步和异步通常用来形容一次方法调用,同步方法,调用者必须等到方法调用返回后,才能继续后续的行为,异步方法调用会立即返回,调用者就可 ...

  6. C# null和" "的区别

    String str1 = null;   str引用为空 String str2 = "";      str引用一个空串 也就是null没有分配空间,""分 ...

  7. iOS 10 隐私权限设置

    iOS 10 开始对隐私权限更加严格,如果你不设置就会直接崩溃,现在很多遇到崩溃问题了,一般解决办法都是在info.plist文件添加对应的Key-Value就可以了. 以上Value值,圈出的红线部 ...

  8. 关于altera的fft核使用问题记录

    altera的fft核使用比较特别,今天我做了一下仿真,发现一些问题,现做记录如下: 1,ip配置 parameters选项卡主要是fft变换的长度和数据长度,旋转因子长度,需要注意的是“Twiddl ...

  9. gogs docker 安装

     1.  gogs 镜像      docker pull gogs/gogs    2.  mysql    docker mysql    3.  本地数据卷配置 mkdir gogs & ...

  10. win7 安装过程中遇到的错误解决方法

    win7 安装过程中遇到的错误解决方法 windows安装无法继续.若要安装windows 请单击 确定 重新启动计算机: 当 出现如上提示的时候,按下shift+f10 会打开命令窗口,进入到C:\ ...