基于python實現(xiàn)操作redis及消息隊列
更新時間:2020年08月27日 09:30:39 作者:295631788
這篇文章主要介紹了基于python操作redis及消息隊列,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
操作 redis
import redis
redisPool = redis.ConnectionPool(host='192.168.100.50', port=6379, db=8)
redis= redis.Redis(connection_pool=redisPool)
redis.set('key','values')
redis.get('com')
redis.append('keys','values')
redis.delete('keys')
print(redis.getset('name','Mike')) #賦值name為Mike并返回上一次的value
print(redis.mget(['name','age'])) #輸出name鍵和age鍵的value
print(redis.setnx('newname','james')) #如果鍵值不存在,則賦值
print(redis.mset({'name1':'smith','name2':'curry'})) #批量賦值
print(redis.msetnx({'name3':'ltf','name4':'lsq'})) #不存在才批量賦值
print(redis.incr('age',1)) #age對應(yīng)的value 加1
print(redis.decr('age',5)) #age對應(yīng)的value 減5
print(redis.append('name4','is a sb')) #在name4的value后追加 is a sb 返回字符串長度
print(redis.substr('name',1,4)) #截取鍵 name
print(redis.sadd('tags','Book','Tea','Coffee')) #返回集合長度 3
print(redis.srem('tags','Book')) #返回刪除的數(shù)據(jù)個數(shù)
print(redis.spop('tags')) #隨機(jī)刪除并返回該元素
print(redis.smove('tags','tags1','Coffee'))
print(redis.scard('tags')) # 獲取tags集合的元素個數(shù)
print(redis.sismember('tags', 'Book')) # 判斷Book是否在tags的集合中
print(redis.sinter('tags', 'tags1')) # 返回集合tags和集合tags1的交集
print(redis.sunion('tags', 'tags1')) # 返回集合tags和集合tags1的并集
print(redis.sdiff('tags', 'tags1')) # 返回集合tags和集合tags1的差集
print(redis.smembers('tags')) # 返回集合tags的所有元素
print(redis.hset('price','cake',5)) # 向鍵名為price的散列表添加映射關(guān)系,返回1 即添加的映射個數(shù)
print(redis.hsetnx('price','book',6)) # 向鍵名為price的散列表添加映射關(guān)系,返回1 即添加的映射個數(shù)
print(redis.hget('price', 'cake')) # 獲取鍵名為cake的值 返回5
print(redis.hmset('price',{'banana':2,'apple':3,'pear':6,'orange':7})) #批量添加映射
print(redis.hmget('price', ['apple', 'orange'])) # 查詢apple和orange的值 輸出 b'3',b'7'
print(redis.hincrby('price','apple',3)) #apple映射加3 為6
print(redis.hexists('price', 'banana')) # 在price中banana是否存在 返回True
print(redis.hdel('price','banana')) #從price中刪除banana 返回1
print(redis.hlen('price')) # 輸出price的長度
print(redis.hkeys('price')) # 輸出所有的映射鍵名
print(redis.hvals('price')) # 輸出所有的映射鍵值
print(redis.hgetall('price')) # 輸出所有的映射鍵對
print(redis.rpush('list',1,2,3)) #向鍵名為list的列表尾部添加1,2,3 返回長度
print(redis.lpush('list',0)) #向鍵名為list的列表頭部添加0 返回長度
print(redis.llen('list')) #返回列表的長度
print(redis.lrange('list',1,3)) #返回起始索引為1 終止索引為3的索引范圍對應(yīng)的列表
print(redis.lindex('list',1)) #返回索引為1的元素-value
print(redis.lset('list',1,5)) #將list的列表索引為1的重新賦值為5
print(redis.lpop('list')) #刪除list第一個元素
print(redis.rpop('list')) #刪除list最后一個元素
print(redis.blpop('list')) #刪除list第一個元素
print(redis.brpop('list')) #刪除最后一個元素
print(redis.rpoplpush('list','list1')) #刪除list的尾元素并將其添加到list1的頭部
消息隊列使用例子
import redis
import json
redisPool = redis.ConnectionPool(host='192.168.100.50', port=6379, db=8)
client = redis.Redis(connection_pool=redisPool)
# 順序插入五條數(shù)據(jù)到redis隊列,sort參數(shù)是用來驗證彈出的順序
while True:
num = 0
for i in range(0, 100):
num = num + 1
# params info
params_dict = {"name": f"test {num}", "sort":num}
client.rpush("test", json.dumps(params_dict))
# 查看目標(biāo)隊列數(shù)據(jù)
result = client.lrange("test", 0, 100)
print(result)
import time
time.sleep(10)
import redis
import time
import multiprocessing
import time
import os
import random
redisPool = redis.ConnectionPool(host='192.168.100.50', port=6379, db=8)
client = redis.Redis(connection_pool=redisPool)
def test1(msg):
t_start = time.time()
print("%s開始執(zhí)行,進(jìn)程號為%d" % (msg, os.getpid()))
time.sleep(random.random() * 2)
t_stop = time.time()
print("%s執(zhí)行完成,耗時%.2f" % (msg, t_stop - t_start))
while True:
number = client.llen('test')
print("現(xiàn)在的隊列任務(wù) 條數(shù)是 ", number)
p = 100
if number > p-1:
print("-----start-----")
a = []
for i in range(p):
result = client.lpop("test")
a.append(result)
print("每10條讀取一次", a)
po = multiprocessing.Pool(p)
for i in range(0, p):
# Pool().apply_async(要調(diào)用的目標(biāo),(傳遞給目標(biāo)的參數(shù)元祖,))
# 每次循環(huán)將會用空閑出來的子進(jìn)程去調(diào)用目標(biāo)
po.apply_async(test1, (a[i],))
po.close() # 關(guān)閉進(jìn)程池,關(guān)閉后po不再接收新的請求
po.join() # 等待po中所有子進(jìn)程執(zhí)行完成,必須放在close語句之后
print("-----end-----")
time.sleep(2)
elif number < p and number > 0:
print("-----start-----")
a = []
for i in range(number):
a = []
result = client.lpop("test")
a.append(result)
print("小于10條的 讀取一次 ", a)
po = multiprocessing.Pool(number)
for i in a:
# Pool().apply_async(要調(diào)用的目標(biāo),(傳遞給目標(biāo)的參數(shù)元祖,))
# 每次循環(huán)將會用空閑出來的子進(jìn)程去調(diào)用目標(biāo)
po.apply_async(test1, (a,))
po.close() # 關(guān)閉進(jìn)程池,關(guān)閉后po不再接收新的請求
po.join() # 等待po中所有子進(jìn)程執(zhí)行完成,必須放在close語句之后
print("-----end-----")
time.sleep(2)
elif number == 0:
print("沒有任務(wù)需要處理")
time.sleep(2)
else:
time.sleep(2)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python面向?qū)ο笏枷肱c應(yīng)用入門教程【類與對象】
這篇文章主要介紹了Python面向?qū)ο笏枷肱c應(yīng)用,較為詳細(xì)的分析了Python面向?qū)ο笏枷肱c原理,并結(jié)合實例形式分析了類與對象相關(guān)定義、用法及操作注意事項,需要的朋友可以參考下2019-04-04
機(jī)器學(xué)習(xí)數(shù)據(jù)預(yù)處理之獨熱One-Hot編碼及其代碼詳解
獨熱編碼即 One-Hot 編碼,又稱一位有效編碼。其方法是使用 N位 狀態(tài)寄存器來對 N個狀態(tài) 進(jìn)行編碼,每個狀態(tài)都有它獨立的寄存器位,并且在任意時候,其中只有一位有效,這篇文章主要介紹了機(jī)器學(xué)習(xí)數(shù)據(jù)預(yù)處理之獨熱One-Hot編碼及其代碼詳解,需要的朋友可以參考下2022-07-07
Python?Pandas中數(shù)據(jù)類型查看與轉(zhuǎn)換方法
Pandas提供了豐富的數(shù)據(jù)類型系統(tǒng)以及靈活的類型轉(zhuǎn)換方法,下面小編就來詳細(xì)介紹一下如何查看Pandas數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)類型和進(jìn)行有效的類型轉(zhuǎn)換吧2025-04-04
簡介Python的collections模塊中defaultdict類型的用法
這里我們來簡介Python的collections模塊中defaultdict類型的用法,與內(nèi)置的字典類最大的不同在于初始化上,一起來看一下:2016-07-07
python中websockets與主線程傳遞參數(shù)的實現(xiàn)
本文主要介紹了python中websockets與主線程傳遞參數(shù)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-02-02
Python 字符串轉(zhuǎn)換為整形和浮點類型的方法
今天小編就為大家分享一篇Python 字符串轉(zhuǎn)換為整形和浮點類型的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07

