欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python定時從Mysql提取數(shù)據(jù)存入Redis的實現(xiàn)

 更新時間:2020年05月03日 15:39:52   作者:wzqnls  
這篇文章主要介紹了Python定時從Mysql提取數(shù)據(jù)存入Redis的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

設(shè)計思路:

1.程序一旦run起來,python會把mysql中最近一段時間的數(shù)據(jù)全部提取出來

2.然后實例化redis類,將數(shù)據(jù)簡單解析后逐條傳入redis隊列

3.定時器設(shè)計每天凌晨12點開始跑

ps:redis是個內(nèi)存數(shù)據(jù)庫,做后臺消息隊列的緩存時有很大的用處,有興趣的小伙伴可以去查看相關(guān)的文檔。

 # -*- coding:utf-8 -*- 

import MySQLdb
import schedule
import time
import datetime
import random
import string
import redis

# get the data from mysql
class FromSql(object):
  def __init__(self, conn):
    self.conn = conn

  def acquire(self):
    cursor = self.conn.cursor()
    try:
      sql = "SELECT * FROM test WHERE TO_DAYS(NOW()) - TO_DAYS(t) <= 1"

      cursor.execute(sql)
      rs = cursor.fetchall()
      #print (rs)
      for eve in rs:

        print('%s, %s, %s, %s' % eve)
      copy_rs = rs
      cursor.close()

      return copy_rs 

    except Exception as e:
      print("The error: %s" % e)


class RedisQueue(object):

  def __init__(self, name, namespace='queue', **redis_kwargs):
    """The default connection parameters are: host='localhost', port=6379, db=0"""
    self.__db= redis.Redis(**redis_kwargs)
    self.key = '%s:%s' %(namespace, name)

  def qsize(self):
    return self.__db.llen(self.key)

  def put(self, item):
    self.__db.rpush(self.key, item)

  def get(self, block=True, timeout=None):

    if block:
      item = self.__db.blpop(self.key, timeout=timeout)
    else:
      item = self.__db.lpop(self.key)

    if item:
      item = item[1]
    return item

  def get_nowait(self):
    return self.get(False)


if __name__ == "__main__":
  # connect mysqldb
  conn_sql = MySQLdb.connect(
            host = '127.0.0.1',
            port = 3306,
            user = 'root',
            passwd = '',
            db = 'test',
            charset = 'utf8'
            )


def job_for_redis():
    get_data = FromSql(conn_sql)
    data = get_data.acquire()

    q = RedisQueue('test',host='localhost', port=6379, db=0)
    for single_data in data:
      for meta_data in single_data:
        q.put(meta_data)
        print(meta_data)
    print("All data had been inserted.") 

"""
  try:
    schedule.every().day.at("00:00").do(job_for_redis)
  except Exception as e:
    print('Error: %s'% e)
#  finally:
#    conn.close()

  while True:
    schedule.run_pending()
    time.sleep(1)
"""

補充知識:python定時獲取匯率存入數(shù)據(jù)庫

python定時任務(wù):

我們可以使用 輕量級的第三方模塊schedule。首先先安裝:pip install schedule

定時任務(wù)的的小測試:

import schedule
import time
 
def job():
  print("I'm working...")
 
schedule.every(10).minutes.do(job)       # 每隔10分鐘執(zhí)行一次任務(wù)
schedule.every().hour.do(job)          # 每隔一小時執(zhí)行一次任務(wù)
schedule.every().day.at("10:30").do(job)    # 每天10:30執(zhí)行一次任務(wù)
schedule.every(5).to(10).days.do(job)      # 每5-10天執(zhí)行一次任務(wù)
schedule.every().monday.do(job)         # 每周一的這個時候執(zhí)行一次任務(wù)
schedule.every().wednesday.at("13:15").do(job) # 每周三13:15執(zhí)行一次任務(wù)
 
while True:
  schedule.run_pending()

獲取數(shù)據(jù)存入數(shù)據(jù)庫:(格式可能不太對,還有一些符號。自己修改一下即可)

import pymysql
import schedule
import time
import requests
import pandas
from sqlalchemy import create_engine

#獲取美元的所有外匯
def job():
  content = '美元'
  url = 'http://www.boc.cn/sourcedb/whpj/index.html' #外匯數(shù)據(jù)地址
  html = requests.get(url).content.decode('utf-8')

  index = html.index('<td>' + content + '</td>')
  str = html[index:index+300]
  result = re.findall('<td>(.*?)</td>',str)

  print("幣種:" + result[0])
  print("現(xiàn)匯買入價:" + result[1])
  print("現(xiàn)鈔買入價:" + result[2])
  print("現(xiàn)匯賣出價:" + result[3])
  print("現(xiàn)鈔賣出價:" + result[4])
  print("中行結(jié)算價:" + result[5])
  print("發(fā)布時間:" + result[6] + ' ' + result[7])
  
 #本地地址 數(shù)據(jù)庫賬號 密碼  數(shù)據(jù)庫名
  db = pymysql.connect('localhost','root','root','pinyougoudb')
  cursor = db.cursor()
  
 #sql語句
  sql = "update tb_money set huiBuy = %s,chaoBuy = %s,huiSale = %s,chaoSale = %s,centerResult= %s,publishTime = '%s' where typeId = '%s'" % (result[1], result[2], result[3], result[4], result[5], result[6] + ' ' + result[7], result[0])

  cursor.execute(sql)
  db.commit()
  print('success')

 # 查詢語句,將存入的數(shù)據(jù)查出來
  # sqlalchemy 進行數(shù)據(jù)庫初始化
  engine = create_engine('mysql+pymysql://root:root@localhost:3306/pinyougoudb')
  sql = '''select * from tb_money'''

  # pandas 進行數(shù)據(jù)庫讀寫
  df = pandas.read_sql_query(sql,engine)
  print(df)

  db.commit()


# 每隔幾分中刷新一次
#schedule.every(0.1).minutes.do(job)

#每天什么時候刷新
schedule.every().day.at("09:29").do(job)
schedule.every().day.at("09:30").do(job)

#一直循環(huán) 知道滿足條件執(zhí)行
while True:
  schedule.run_pending()

以上這篇Python定時從Mysql提取數(shù)據(jù)存入Redis的實現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python數(shù)據(jù)集庫Vaex秒開100GB加數(shù)據(jù)

    Python數(shù)據(jù)集庫Vaex秒開100GB加數(shù)據(jù)

    這篇文章主要為大家介紹了Python數(shù)據(jù)集庫Vaex秒開100GB加數(shù)據(jù)實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • Python Pexpect庫的簡單使用方法

    Python Pexpect庫的簡單使用方法

    這篇文章主要介紹了Python Pexpect庫的簡單使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • 利用Python輕松實現(xiàn)視頻轉(zhuǎn)GIF動圖

    利用Python輕松實現(xiàn)視頻轉(zhuǎn)GIF動圖

    在看視頻的時候覺得某段非常有意思想弄成動圖,但是無從下手!本文就將介紹如何利用Python搞定這一需求,感興趣的小伙伴可以學(xué)習(xí)一下
    2022-01-01
  • python安裝cx_Oracle和wxPython的方法

    python安裝cx_Oracle和wxPython的方法

    這篇文章主要介紹了python安裝cx_Oracle和wxPython的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • python對DICOM圖像的讀取方法詳解

    python對DICOM圖像的讀取方法詳解

    DICOM(Digital Imaging and Communications in Medicine)即醫(yī)學(xué)數(shù)字成像和通信,是醫(yī)學(xué)圖像和相關(guān)信息的國際標(biāo)準(zhǔn)(ISO 12052)。下面這篇文章主要給大家介紹了關(guān)于python對DICOM圖像讀取的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-07-07
  • Python基于類路徑字符串獲取靜態(tài)屬性

    Python基于類路徑字符串獲取靜態(tài)屬性

    這篇文章主要介紹了Python基于類路徑字符串獲取靜態(tài)屬性,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • 記錄一下scrapy中settings的一些配置小結(jié)

    記錄一下scrapy中settings的一些配置小結(jié)

    這篇文章主要介紹了記錄一下scrapy中settings的一些配置小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • python 判斷文件或文件夾是否存在

    python 判斷文件或文件夾是否存在

    這篇文章主要介紹了python 判斷文件或文件夾是否存在,Python 操作文件時,我們一般要先判斷指定的文件或目錄是否存在,不然容易產(chǎn)生異常,下面我們就來學(xué)習(xí)如何利用python檢查文件是否存在吧
    2022-03-03
  • pycharm安裝和首次使用教程

    pycharm安裝和首次使用教程

    這篇文章主要為大家詳細(xì)介紹了PyCharm安裝使用教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 關(guān)于Python文本生成的Beam?Search解碼問題

    關(guān)于Python文本生成的Beam?Search解碼問題

    這篇文章主要介紹了Python文本生成的Beam?Search解碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07

最新評論