forked from jhao104/proxy_pool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRedisClient.py
123 lines (104 loc) · 3.15 KB
/
RedisClient.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
# -*- coding: utf-8 -*-
# !/usr/bin/env python
'''
self.name为Redis中的一个key
2017/4/17 修改pop
'''
# ############################
# 已弃用,
# SsdbClient.py 支持redis
##############################
import json
import random
import redis
import sys
class RedisClient(object):
"""
Reids client
"""
def __init__(self, name, host, port):
"""
init
:param name:
:param host:
:param port:
:return:
"""
self.name = name
self.__conn = redis.Redis(host=host, port=port, db=0)
def get(self):
"""
get random result
:return:
"""
key = self.__conn.hgetall(name=self.name)
# return random.choice(key.keys()) if key else None
# key.keys()在python3中返回dict_keys,不支持index,不能直接使用random.choice
# 另:python3中,redis返回为bytes,需要解码
rkey = random.choice(list(key.keys())) if key else None
if isinstance(rkey, bytes):
return rkey.decode('utf-8')
else:
return rkey
# return self.__conn.srandmember(name=self.name)
def put(self, key):
"""
put an item
:param value:
:return:
"""
key = json.dumps(key) if isinstance(key, (dict, list)) else key
return self.__conn.hincrby(self.name, key, 1)
# return self.__conn.sadd(self.name, value)
def getvalue(self, key):
value = self.__conn.hget(self.name, key)
return value if value else None
def pop(self):
"""
pop an item
:return:
"""
key = self.get()
if key:
self.__conn.hdel(self.name, key)
return key
# return self.__conn.spop(self.name)
def delete(self, key):
"""
delete an item
:param key:
:return:
"""
self.__conn.hdel(self.name, key)
# self.__conn.srem(self.name, value)
def inckey(self, key, value):
self.__conn.hincrby(self.name, key, value)
def getAll(self):
# return self.__conn.hgetall(self.name).keys()
# python3 redis返回bytes类型,需要解码
if sys.version_info.major == 3:
return [key.decode('utf-8') for key in self.__conn.hgetall(self.name).keys()]
else:
return self.__conn.hgetall(self.name).keys()
# return self.__conn.smembers(self.name)
def get_status(self):
return self.__conn.hlen(self.name)
# return self.__conn.scard(self.name)
def changeTable(self, name):
self.name = name
if __name__ == '__main__':
redis_con = RedisClient('proxy', 'localhost', 6379)
# redis_con.put('abc')
# redis_con.put('123')
# redis_con.put('123.115.235.221:8800')
# redis_con.put(['123', '115', '235.221:8800'])
# print(redis_con.getAll())
# redis_con.delete('abc')
# print(redis_con.getAll())
# print(redis_con.getAll())
redis_con.changeTable('raw_proxy')
redis_con.pop()
# redis_con.put('132.112.43.221:8888')
# redis_con.changeTable('proxy')
print(redis_con.get_status())
print(redis_con.getAll())