利用 Python 只連接一次 MySQL

来源:http://www.cnblogs.com/liuning8023/archive/2016/01/29/5168600.html
-Advertisement-
Play Games

Github 地址 項目背景 最近做個項目,需要進行試駕分析,所謂“試駕”,是指顧客在 4S 店指定人員的陪同下,沿著指定的路線駕駛車輛,從而瞭解這款汽車的行駛性能和操控性能。通常,無論是車廠(製造商),還是4S店(經銷商),對車輛的試駕都比較感興趣。從車廠的角度,不僅僅可以知道某輛車是否受歡迎,還...


Github 地址

項目背景


最近做個項目,需要進行試駕分析,所謂“試駕”,是指顧客在 4S 店指定人員的陪同下,沿著指定的路線駕駛車輛,從而瞭解這款汽車的行駛性能和操控性能。通常,無論是車廠(製造商),還是4S店(經銷商),對車輛的試駕都比較感興趣。從車廠的角度,不僅僅可以知道某輛車是否受歡迎,還可以監控4S店對車輛的使用的情況(車廠肯定不願意原本是用來賣錢的車被私用)。

所以,試駕分析,是利用車載設備,比如 OBD、車機,或是其他能監控車輛的設備,我們採用 OBD,發送給軟體平臺一系列車輛實時狀態消息,如GPS定位、百公裡耗油、報警等,平臺根據這些消息,以及4S店設置的電子圍欄,進行試駕分析,包括試駕開始時間、試駕結束時間、試駕持續時間、行駛里程、油耗、平均速度、最大速度等。

試駕分析演算法,雖然有一定難度(核心演算法1000多行),但跟測試這個演算法相比,簡直容易得不了。OBD 由另一個公司生產,他們只給了我們文檔,來說明OBD消息二進位流的格式,由我們自己解析,再進行試駕分析。事實上,這個項目我的工作,要完成兩個程式:消息解析服務和試駕分析服務,2個月完成,一共將近3.8萬行代碼,但前期沒有任何手段進行測試,直到3個月後公司安排實車測試~

但問題來了,如果每次想測試軟體和演算法,都要用實車,這成本太高了,尤其是時間成本。程式員的時間很寶貴的。唯一的辦法是,另寫一個程式,能夠模擬 OBD發送消息,相當於把之前實車的數據“回放”一遍。不僅如此,最好能自定義幾個命令,來控制消息的發送以及電子圍欄和相關時間的設置,比如,

  • “send”表示發送指定消息;
  • “wait”表示等待指定時間後再發送一下一個消息;
  • “set”表示設置電子圍欄,或採集時間,或報備時間,即試駕分析只在採集時間內、報備時間外進行。
  • “echo”表示顯示信息。

示例:

send 5830 
wait 1 
send 5841 
wait 1 
echo 將發送報警... 
send 5842 
…… 

事實也是這麼做的。我用 Python 寫了一個程式,並利用 nestordeharo/mysql-python-class 庫訪問 MySQL,可意外來了,時不時地程式會報錯,MySQL 拒絕我的連接請求,有時一星期沒事,有時完全無法使用。雖然我也知道,這個程式訪問資料庫太頻繁,效率太低,但只是作為內部測試工具,沒必要寫的太好,而且一秒內訪問兩個資料庫,MySQL 不至於這麼弱吧,我是懷疑運維那邊,資料庫沒配置好~但實在受不了了,嚴重影響測試進度,就棄用上面的庫,自己寫個簡單的 Python 庫,它只訪問一次資料庫。


功能簡介

該 Python 庫只訪問一次 MySQL 資料庫。


API

假設,有個表 t1,它有四個欄位:id、name、age、loc。

* open(self)

打開資料庫。

* close(self)

關閉資料庫。

* select(self, table, where=None, args, *kwargs)

若查找ID為1的用戶:

SELECT id,name FROM t1 WHERE id='1'

可以這樣調用該方法:

select('t1', 'id = %s ', 'id', 'name', id='1')

* insert(self, table, args, *kwargs)

若想插入一條記錄:

INSERT INTO t1(id, name, age, loc) VALUES(2,'person2', '20', '北京')

可以這樣調用該方法:

insert('t1', id='2', name='person2', age='20')

* update(self, table, where=None, args, *kwargs)

若想更新一條記錄:

UPDATE t1 SET name='p2' WHERE id='2'

可以這樣調用該方法:

update('t1', 'id = %s ', '2', name='p2')

* delete(self, table, where=None, *args)

若想刪除ID為2的記錄:

DELETE FROM t1 where id='2'

可以這樣調用該方法:

delete('t1', ' id = %s ', '2')

* select_advanced(self, sql, *args)

若想查找北京地區的成年人:

SELECT id,name,age FROM t1 WHERE age>18 and loc='北京'

可以這樣調用該方法:

select_advanced('SELECT id,name FROM t1 WHERE age > %s AND loc = %s', ('age', '18'),('loc','北京'))


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近項目中有一個這樣的需求,要做一個定時任務功能,定時備份資料庫的操表,將表數據寫入txt文件。因為文件的讀寫路徑可能需要隨時改動,所以寫死或者寫成靜態變數都不方便,就考慮使用配置文件,這裡總結些配置文件用法。 一、Java Properties類 1、Java中有個比較重要的的類Propertie...
  • 1 背景概述 數通暢聯本著分享傳遞的理念已經將產品家族中的核心產品開源,目的在於滿足客戶與伙伴的OEM需求,以及為廣大IT愛好者的集成工具提供多一種選擇,多一種便利。如果需要對產品進行擴展開發或者更深層次的瞭解產品可以在svn中check out源碼。 本文詳細介紹BPM、Portal、SMC工程在
  • 題外:做過一陣開發,後來接觸了很多東西,改變了觀念,比較浮躁,嘗試過轉行各種崗位,最後做了網路運營,其間走的彎路中學到了很多東西,時間推移開發扔了很久,故此閑暇時間複習下。 概述:沒有寫技術博客的經驗,看過的博客也不喜歡長篇大論,比較喜歡直觀看代碼,學習的習慣是行動中理解,如果需要深入瞭解我會看一些
  • 一、memcached是什麼? 二、memcached不互相通信的分散式 三、安裝步驟 四、本文介紹的命令主要包括: 存入命令(Storage commands) 取回命令(Retrieval command) 刪除命令(Deletion) 統計(Statistics) 其他命令 五、java客戶端
  • 類和結構體: 定義語法: class SomeClass{ //定義類的成員 var name:String = "" var age:Int = 18 var job:String?//可選可以為空 } struct SomeStruct{ //定義結構體的成員 let sex:String =
  • Python中的變數不需要聲明。每個變數在使用前都必須賦值,變數賦值以後該變數才會被創建。 在Python中變數就是變數,是記憶體地址指針,它沒有類型,我們所說的"類型"是變數所指的記憶體中對象的類型。類似於其他java、C中的引用類型。 Python3中有六個標準的數據類型: 字元串(String)數
  • #應用環境:python2.7#!/usr/bin/env python # coding=utf-8 from __future__ import print_function import os try: from urllib import urlencode, quote_plus exce
  • "Gist Link" 看完我想撞牆,為什麼早沒想到。。。
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...