python-sql-faker:輕量級(jí)走搁、易拓展的數(shù)據(jù)庫(kù)智能填充開(kāi)源庫(kù)(Python實(shí)現(xiàn)版)

在開(kāi)發(fā)的過(guò)程中独柑,往往會(huì)碰到要給數(shù)據(jù)庫(kù)填充數(shù)據(jù)的問(wèn)題,為了快速生成盡可能接近真實(shí)的數(shù)據(jù)私植,本人開(kāi)發(fā)了sql-faker忌栅,以下是該開(kāi)源庫(kù)的介紹。

開(kāi)源庫(kù)特性

  • 支持主流的MySQL曲稼、Oracle索绪、SQL Server、SQLite數(shù)據(jù)庫(kù)
  • 支持8種常見(jiàn)數(shù)據(jù)庫(kù)字段類型的智能填充贫悄,并支持自定義拓展
  • 支持一次性插入百萬(wàn)級(jí)別的數(shù)據(jù)
  • 支持事務(wù)
  • 支持python2.7

使用示范

from sql_faker import Faker, DataType, Values, Times, DBHelper
import pymysql

# 設(shè)置數(shù)據(jù)庫(kù)信息
DBHelper.db_setting(db='python_sql_faker',
                    driver=pymysql,
                    user='root',
                    passwd='123456',
                    host='127.0.0.1',
                    port=3306)

#  給user表的四個(gè)字段填充5條數(shù)據(jù)
Faker.table_name("user") \
    .param("name", DataType.USERNAME) \
    .param("age", DataType.AGE) \
    .param("address", DataType.ADDRESS) \
    .param("birthday", DataType.TIME) \
    .insert_count(5) \
    .execute()

上述代碼將生成如下SQL語(yǔ)句者春,并在數(shù)據(jù)庫(kù)中執(zhí)行:

insert into user(name,age,sex,address,birthday) values('武嘆霜', 21, '山西省晉城市澤州縣慶達(dá)路463號(hào)', '2018-02-24 10:56:37')
insert into user(name,age,sex,address,birthday) values('顧什可', 50, '廣西壯族自治區(qū)柳州市融水苗族自治縣德堡路419號(hào)', '2018-04-09 08:10:22')
insert into user(name,age,sex,address,birthday) values('蔡靜隨', 46, '河南省鄭州市鞏義市廣延路240號(hào)', '2018-06-11 23:02:19')
insert into user(name,age,sex,address,birthday) values('韋丸赤', 27, '河南省焦作市博愛(ài)縣浦潤(rùn)路148號(hào)', '2018-02-22 15:52:50')
insert into user(name,age,sex,address,birthday) values('任徐', 54, '河南省新鄉(xiāng)市延津縣漢源路14號(hào)', '2018-07-07 03:48:51')

依賴添加

本開(kāi)源庫(kù)另外依賴了DBUtils和pymysql庫(kù),需要一起進(jìn)行pip安裝清女。

pip install sql-faker
pip install DBUtils
pip install pymysql

如果安裝不成功钱烟,點(diǎn)此連接進(jìn)行下載whl文件 點(diǎn)擊下載

然后在控制臺(tái)中移動(dòng)到文件下載路徑嫡丙,執(zhí)行如下命令:

cd 下載路徑
pip install sql_faker-1.1.7-py2-none-any.whl

注意:默認(rèn)使用MySQL數(shù)據(jù)庫(kù)拴袭,如需更換成Oracle、SQL Server曙博、SQLite等DBUtils連接池支持的數(shù)據(jù)庫(kù)拥刻,可另行添加依賴,并在DBHelper.db_setting(driver=驅(qū)動(dòng)對(duì)象)方法中指定數(shù)據(jù)庫(kù)驅(qū)動(dòng)父泳。

數(shù)據(jù)庫(kù)連接

一般哼、連接屬性設(shè)置

在進(jìn)行插入數(shù)據(jù)之前需要設(shè)置數(shù)據(jù)庫(kù)屬性,如代碼所示:

from sql_faker import DBHelper
import pymysql

# 設(shè)置數(shù)據(jù)庫(kù)信息
DBHelper.db_setting(db='python_sql_faker',
                    driver=pymysql, # 設(shè)置連接驅(qū)動(dòng)
                    user='root',
                    passwd='123456',
                    host='127.0.0.1',
                    port=3306)

可設(shè)置的屬性如下表:

屬性名 說(shuō)明 默認(rèn)值
db 數(shù)據(jù)庫(kù)名 無(wú)
driver 數(shù)據(jù)庫(kù)驅(qū)動(dòng)對(duì)象 pymysql
user 數(shù)據(jù)庫(kù)用戶名 root
passwd 數(shù)據(jù)庫(kù)密碼 12345
host 主機(jī)地址 localhost
port 端口號(hào) 3306

二惠窄、特殊情況

  1. 當(dāng)數(shù)據(jù)庫(kù)屬性值都等于默認(rèn)值時(shí)蒸眠,可只設(shè)置數(shù)據(jù)庫(kù)名:
DBHelper.db_setting('python_sql_faker')

三、支持的驅(qū)動(dòng)類型

# 支持的驅(qū)動(dòng)類型杆融,可在DBHelper.db_setting(driver=驅(qū)動(dòng)對(duì)象)方法指定數(shù)據(jù)庫(kù)驅(qū)動(dòng)
# 1.首先在控制臺(tái)進(jìn)行pip安裝
pip install pymysql # mysql
pip install pymssql # sqlserver
pip install cx_Oracle # oracle
pip install sqlite3 # sqlite3

# 2.之后導(dǎo)入所需驅(qū)動(dòng)楞卡,設(shè)置到driver屬性中
DBHelper.db_setting(db='python_sql_faker',
                    driver=cx_Oracle) # 設(shè)置連接驅(qū)動(dòng)

注意 :數(shù)據(jù)庫(kù)配置只需要設(shè)置一次,之后可以多次調(diào)用Faker進(jìn)行插入數(shù)據(jù)操作脾歇。

數(shù)據(jù)插入

一蒋腮、屬性介紹

可設(shè)置的屬性如下表:

屬性名 說(shuō)明
table_name(數(shù)據(jù)庫(kù)表名) 設(shè)置數(shù)據(jù)庫(kù)表名
param(字段名, 數(shù)據(jù)生成器類型①) 設(shè)置數(shù)據(jù)庫(kù)字段名,以及對(duì)應(yīng)的數(shù)據(jù)生成器類型
insert_count(插入條數(shù)) 設(shè)置插入數(shù)據(jù)條數(shù)
execute( ) 生成SQL藕各,顯示在控制臺(tái)池摧,并在數(shù)據(jù)庫(kù)中執(zhí)行
only_show_sql( ) 生成SQL,并顯示在控制臺(tái)
ignored( ) 不執(zhí)行任何操作

注意:① 數(shù)據(jù)生成器類型激况,必須是DataType枚舉值作彤,或?qū)崿F(xiàn)了RandomData接口的類膘魄。

使用示例:

// 給user表的四個(gè)字段填充5條數(shù)據(jù)
Faker.table_name("user") \
    .param("name", DataType.USERNAME) \
    .param("age", DataType.AGE) \
    .param("sex", DataType.SEX) \
    .param("birthday", DataType.TIME) \
    .insert_count(5) \
    .execute()

// 給user表的兩個(gè)字段生成5條SQL,并顯示在控制臺(tái)
Faker.table_name("user") \
    .param("name", DataType.USERNAME) \
    .param("age", DataType.AGE) \
    .insert_count(5) \
    .only_show_sql()

// 不執(zhí)行任何操作宦棺,不生成SQL瓣距,不顯示在控制臺(tái)
Faker.table_name("user") \
    .param("name", DataType.USERNAME) \
    .param("age", DataType.AGE) \
    .insert_count(5) \
    .ignored()

二、插入數(shù)據(jù)的方式

本開(kāi)源庫(kù)一共支持三種插入數(shù)據(jù)的方式代咸,可以混合使用蹈丸。

1. 使用DataType指定數(shù)據(jù)類型

DataType一共支持8種枚舉類型,如下表所示:

屬性名 說(shuō)明 類型 示例值
ID 用戶ID 19位的數(shù)字型UUID字符串 1049120504188764160
USERNAME 用戶名 長(zhǎng)度為2到4個(gè)字的中文名 武嘆霜
TIME 時(shí)間 一年前到現(xiàn)在的時(shí)間范圍內(nèi)任意一個(gè)時(shí)刻 2018-03-01 12:41:00
PHONE 手機(jī)號(hào) 11位手機(jī)號(hào) 13192668109
ADDRESS 地址 國(guó)內(nèi)地址呐芥,詳細(xì)到門(mén)牌號(hào) 四川省綿陽(yáng)市鹽亭縣北利路738號(hào)
AGE 年齡 18到60歲的數(shù)字 19
SEX 性別 字符逻杖,0:男,1:女 '1'
EMAIL 郵箱 常見(jiàn)郵箱字符串 Alex705@gmail.com

使用示例:

// 給user表的8個(gè)字段填充1條數(shù)據(jù)
Faker.table_name("user") \
    .param("id", DataType.ID) \
    .param("name", DataType.USERNAME) \
    .param("birthday", DataType.TIME) \
    .param("phone", DataType.PHONE) \
    .param("address", DataType.ADDRESS) \
    .param("age", DataType.AGE) \
    .param("sex", DataType.SEX) \
    .param("email", DataType.EMAIL) \
    .insert_count(1) \
    .execute()

對(duì)應(yīng)生成的SQL語(yǔ)句如下:

insert into 
user(
  id, name, birthday,
  phone, address, age,
  sex, email
) 
values(
  '1049120504188764160', '武嘆霜', '2018-03-01 12:41:00',
  '13192668109', '四川省綿陽(yáng)市鹽亭縣北利路73號(hào)', 19,
   '1', 'Alex705@gmail.com'
)

2. 使用 Values.of()系列方法生成取值范圍

Values類共有以下8種生成取值范圍方法思瘟,如下表:

方法名 取值范圍 示例值
Values.of(可變長(zhǎng)參數(shù)) 從可變長(zhǎng)參數(shù)中任意抽取一個(gè)值 "優(yōu)品", "良品", "次品"
Values.of_int_range(起始值,結(jié)束值) 在[起始值, 結(jié)束值]的范圍內(nèi)取一個(gè)整數(shù) 33
Values.of_float_range(起始值,結(jié)束值,精度) 在[起始值, 結(jié)束值]的范圍內(nèi)取一個(gè)浮點(diǎn)數(shù)荸百,默認(rèn)精確到小數(shù)點(diǎn)后2位,最多10位 123.333333f
Values.of_time_range(開(kāi)始時(shí)間滨攻,結(jié)束時(shí)間) 在[開(kāi)始時(shí)間, 結(jié)束時(shí)間]的范圍內(nèi)取一個(gè)時(shí)間够话,精確到秒 2018-03-14 13:21:11

另外,Times類中還有用于設(shè)定時(shí)間的兩個(gè)方法:

方法名 說(shuō)明
Times.of(年,月,日) 用于生成時(shí)間光绕,精確到日
Times.of(年,月,日,時(shí),分,秒) 用于生成時(shí)間女嘲,精確到秒

使用示例:

// 給product表的9個(gè)字段填充1條數(shù)據(jù)
Faker.table_name("product")\
      .param("type", Values.of("優(yōu)品", "良品", "次品"))\
      .param("person_count", Values.of_int_range(20, 50))\
      .param("enter_price", Values.of_float_range(12.33, 34.57))\
      .param("outcome_price", Values.of_float_range(100.004132, 240.281424, 6))\
      .param("firstTime", Values.of_time_range(Times.of(2018,3,22), Times.of(2018,10,22)))\
      .param("secondTime",
             Values.of_time_range(
                Times.of(2018,3,22,11,23,24),
                Times.of(2018,10,22,22,15,17)
             )
       )\
      .insert_count(1)\
      .only_show_sql()

對(duì)應(yīng)生成的SQL語(yǔ)句如下:

insert into 
product(
  type, person_count, total_count,
  enter_price, outcome_price, speed,
  salary, firstTime, secondTime
) 
values(
  '良品', 33, 777777777,
  22.22, 123.333333, 788.31,
  1820.4231, '2018-03-14 00:00:00', '2018-03-14 13:21:11'
)

3. 繼承RandomData類,重寫(xiě)create()方法诞帐,提供可隨機(jī)生成的返回值

RandomData類的代碼如下:

class RandomData:
    """隨機(jī)值抽象類欣尼,子類必須實(shí)現(xiàn)create方法"""
    __metaclass__ = ABCMeta

    @abstractmethod
    def create(self):
        pass

繼承該類,并重寫(xiě)create( )方法提供一個(gè)可隨機(jī)生成的返回值停蕉,該返回值就是數(shù)據(jù)庫(kù)字段對(duì)應(yīng)插入的值愕鼓。

使用示例:

  1. 創(chuàng)建一個(gè)自定義類EnglishNameRandom,繼承RandomData類慧起,并提供一個(gè)可隨機(jī)生成的返回值菇晃。
import random
from sql_faker import Faker, DataType, Values, Times, DBHelper, RandomData

# 英文名數(shù)據(jù)生成器
class EnglishNameRandom(RandomData):
    def create(self):
        # 使用choice()方法從列表中隨機(jī)抽取一個(gè)值,作為返回值
        return random.choice(['jack', 'andy', 'kim']) 
  1. 在Faker中給字段指定使用EnglishNameRandom類型的生成器完慧。
// 指定name字段使用EnglishNameRandom類進(jìn)行隨機(jī)值的生成
Faker.table_name("user")\
       .param("name", EnglishNameRandom)\
       .param("age", Values.of_int_range(20, 50))\
       .param("address", DataType.ADDRESS)\
       .insert_count(5)\
       .execute()

對(duì)應(yīng)生成的SQL語(yǔ)句如下:

insert into user(name, age, address) 
values('Andy Wang', 23, '四川省綿陽(yáng)市鹽亭縣北利路73號(hào)')

PS:如果有任何建議谋旦,可以在Issues中提出,如添加DataType的默認(rèn)類型等屈尼。

License

The python-sql-faker is released under MIT License.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市拴孤,隨后出現(xiàn)的幾起案子脾歧,更是在濱河造成了極大的恐慌,老刑警劉巖演熟,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鞭执,死亡現(xiàn)場(chǎng)離奇詭異司顿,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)兄纺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén)大溜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人估脆,你說(shuō)我怎么就攤上這事钦奋。” “怎么了疙赠?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵付材,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我圃阳,道長(zhǎng)厌衔,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任捍岳,我火速辦了婚禮富寿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘锣夹。我一直安慰自己页徐,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布晕城。 她就那樣靜靜地躺著泞坦,像睡著了一般。 火紅的嫁衣襯著肌膚如雪砖顷。 梳的紋絲不亂的頭發(fā)上贰锁,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音滤蝠,去河邊找鬼。 笑死物咳,一個(gè)胖子當(dāng)著我的面吹牛锣险,可吹牛的內(nèi)容都是我干的览闰。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼压鉴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼崖咨!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起油吭,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤署拟,失蹤者是張志新(化名)和其女友劉穎歌豺,沒(méi)想到半個(gè)月后推穷,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡类咧,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年馒铃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了轮听。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡血巍,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出述寡,到底是詐尸還是另有隱情,我是刑警寧澤鲫凶,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站螟炫,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏掸屡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一仅财、第九天 我趴在偏房一處隱蔽的房頂上張望碗淌。 院中可真熱鬧盏求,春花似錦亿眠、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)爹耗。三九已至,卻和暖如春倦始,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鞋邑。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工账蓉, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留枚碗,地道東北人铸本。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像箱玷,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锡足,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354