自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

推薦一款Python開源庫(kù),技術(shù)人必備的造數(shù)據(jù)神器!

開發(fā) 后端
今天給大家分享一款Python造數(shù)據(jù)利器:Faker庫(kù),利用它可以生成一批各種各樣的看起來“像真的一樣”的假數(shù)據(jù)。

1. 背景

在軟件需求、開發(fā)、測(cè)試過程中,有時(shí)候需要使用一些測(cè)試數(shù)據(jù),針對(duì)這種情況,我們一般要么使用已有的系統(tǒng)數(shù)據(jù),要么需要手動(dòng)制造一些數(shù)據(jù)。由于現(xiàn)在的業(yè)務(wù)系統(tǒng)數(shù)據(jù)多種多樣,千變?nèi)f化。在手動(dòng)制造數(shù)據(jù)的過程中,可能需要花費(fèi)大量精力和工作量,此項(xiàng)工作既繁復(fù)又容易出錯(cuò),比如要構(gòu)造一批用戶三要素(姓名、手機(jī)號(hào)、身份證)、構(gòu)造一批銀行卡數(shù)據(jù)、或構(gòu)造一批地址通訊錄等。

這時(shí)候,人們常常為了偷懶快捷,測(cè)試數(shù)據(jù)大多數(shù)可能是類似這樣子的: 

  1. 測(cè)試, 1300000 000123456  
  2. 張三, 1310000 000123456  
  3. 李四, 1320000 000234567  
  4. 王五, 1330000 000345678 

測(cè)試數(shù)據(jù)中包括了大量的“測(cè)試XX”,要么就是隨手在鍵盤上一頓亂敲,都是些無意義的假數(shù)據(jù)。

你是不是這樣做的呢?坦白的說,有過一段時(shí)間,筆者偶爾也是這么干的。

但是,細(xì)想一下,這樣的測(cè)試數(shù)據(jù),不僅要自己手動(dòng)敲,還假的不能再假,浪費(fèi)時(shí)間、浪費(fèi)人力、數(shù)據(jù)價(jià)值低。

而且,部分?jǐn)?shù)據(jù)的手工制造還無法保障:比如UUID類數(shù)據(jù)、MD5、SHA加密類數(shù)據(jù)等。

為了幫助大家解決這個(gè)問題,更多還是提供種一種解決方案或思路,今天給大家分享一款Python造數(shù)據(jù)利器:Faker庫(kù),利用它可以生成一批各種各樣的看起來“像真的一樣”的假數(shù)據(jù)。

2. Faker介紹 、安裝

2.1 Faker是什么

Faker是一個(gè)Python包,主要用來創(chuàng)建偽數(shù)據(jù),使用Faker包,無需再手動(dòng)生成或者手寫隨機(jī)數(shù)來生成數(shù)據(jù),只需要調(diào)用Faker提供的方法,即可完成數(shù)據(jù)的生成。

項(xiàng)目地址:

2.2 安裝

安裝 Faker 很簡(jiǎn)單,使用 pip 方式安裝: 

  1. pip install Faker 

除了pip 安裝,也可以通過上方提供的github地址,來下載編譯安裝。 

  1. (py3_env) ➜  py3_env pip show faker  
  2. Name: Faker  
  3. Version: 4.1.1  
  4. Summary: Faker is a Python package that generates fake data for you.  
  5. Home-page: https://github.com/joke2k/faker  
  6. Author: joke2k  
  7. Author-email: joke2k@gmail.com  
  8. License: MIT License  
  9. Location: /Users/xxx/work_env/py3_env/lib/python3.7/site-packages  
  10. Requires: python-dateutil, text-unidecode  
  11. Required-by: 

3. Faker常用使用

3.1 基本用法

Faker 的使用也是很簡(jiǎn)單的,從 faker 模塊中導(dǎo)入類,然后實(shí)例化這個(gè)類,就可以調(diào)用方法使用了: 

  1. from faker import Faker  
  2. fake = Faker()  
  3. name = fake.name()  
  4. address = fake.address()  
  5. print(name)  
  6. print(address)  
  7. # 輸出信息  
  8. Ashley Love  
  9. 074 Lee Village Suite 464  
  10. Dawnborough, RI 44234 

這里我們?cè)炝艘粋€(gè)名字和一個(gè)地址,由于 Faker 默認(rèn)是英文數(shù)據(jù),所以如果我們需要造其他語(yǔ)言的數(shù)據(jù),可以使用 locale參數(shù),例如: 

  1. from faker import Faker  
  2. fake = Faker(locale='zh_CN' 
  3. name = fake.name()  
  4. address = fake.address()  
  5. print(name)  
  6. print(address)  
  7. # 輸出信息  
  8. 張艷  
  9. 海南省上海市朝陽(yáng)邱路y座 175208 

是不是看起來還不錯(cuò),但是有一點(diǎn)需要注意,這里的地址并不是真實(shí)的地址,而是隨機(jī)組合出來的,也就是將省、市、道路之類的隨機(jī)組合在一起。

這里介紹幾個(gè)比較常見的語(yǔ)言代號(hào):

  •  簡(jiǎn)體中文:zh_CN
  •  繁體中文:zh_TW
  •  美國(guó)英文:en_US
  •  英國(guó)英文:en_GB
  •  德文:de_DE
  •  日文:ja_JP
  •  韓文:ko_KR
  •  法文:fr_FR

例如將語(yǔ)言修改為繁體中文fake = Faker(locale='zh_TW'),輸出信息為: 

  1. 楊志宏  
  2. 100 中壢博愛街10號(hào)9樓 

3.2 常用函數(shù)

除了上述介紹的fake.name和fake.address生成姓名和地址兩個(gè)函數(shù)外,常用的faker函數(shù)按類別劃分有如下一些常用方法。

1、地理信息類

  •  fake.city_suffix():市,縣
  •  fake.country():國(guó)家
  •  fake.country_code():國(guó)家編碼
  •  fake.district():區(qū)
  •  fake.geo_coordinate():地理坐標(biāo)
  •  fake.latitude():地理坐標(biāo)(緯度)
  •  fake.longitude():地理坐標(biāo)(經(jīng)度)
  •  fake.postcode():郵編
  •  fake.province():省份
  •  fake.address():詳細(xì)地址
  •  fake.street_address():街道地址
  •  fake.street_name():街道名
  •  fake.street_suffix():街、路

2、基礎(chǔ)信息類

  1.  ssn():生成身份證號(hào)
  2.  bs():隨機(jī)公司服務(wù)名
  3.  company():隨機(jī)公司名(長(zhǎng))
  4.  company_prefix():隨機(jī)公司名(短)
  5.  company_suffix():公司性質(zhì)
  6.  credit_card_expire():隨機(jī)信用卡到期日
  7.  credit_card_full():生成完整信用卡信息
  8.  credit_card_number():信用卡號(hào)
  9.  credit_card_provider():信用卡類型
  10.  credit_card_security_code():信用卡安全碼
  11.  job():隨機(jī)職位
  12.  first_name_female():女性名
  13.  first_name_male():男性名
  14.  last_name_female():女姓
  15.  last_name_male():男姓
  16.  name():隨機(jī)生成全名
  17.  name_female():男性全名
  18.  name_male():女性全名
  19.  phone_number():隨機(jī)生成手機(jī)號(hào)
  20.  phonenumber_prefix():隨機(jī)生成手機(jī)號(hào)段

3、計(jì)算機(jī)基礎(chǔ)、Internet信息類

  1.  ascii_company_email():隨機(jī)ASCII公司郵箱名
  2.  ascii_email():隨機(jī)ASCII郵箱:
  3.  company_email():
  4.  email():
  5.  safe_email():安全郵箱

4、網(wǎng)絡(luò)基礎(chǔ)信息類

  1.  domain_name():生成域名
  2.  domain_word():域詞(即,不包含后綴)
  3.  ipv4():隨機(jī)IP4地址
  4.  ipv6():隨機(jī)IP6地址
  5.  mac_address():隨機(jī)MAC地址
  6.  tld():網(wǎng)址域名后綴(.com,.net.cn,等等,不包括.)
  7.  uri():隨機(jī)URI地址
  8.  uri_extension():網(wǎng)址文件后綴
  9.  uri_page():網(wǎng)址文件(不包含后綴)
  10.  uri_path():網(wǎng)址文件路徑(不包含文件名)
  11.  url():隨機(jī)URL地址
  12.  user_name():隨機(jī)用戶名
  13.  image_url():隨機(jī)URL地址

5、瀏覽器信息類

  1.  chrome():隨機(jī)生成Chrome的瀏覽器user_agent信息
  2.  firefox():隨機(jī)生成FireFox的瀏覽器user_agent信息
  3.  internet_explorer():隨機(jī)生成IE的瀏覽器user_agent信息
  4.  opera():隨機(jī)生成Opera的瀏覽器user_agent信息
  5.  safari():隨機(jī)生成Safari的瀏覽器user_agent信息
  6.  linux_platform_token():隨機(jī)Linux信息
  7.  user_agent():隨機(jī)user_agent信息

6、數(shù)字類

  1.  numerify():三位隨機(jī)數(shù)字
  2.  random_digit():0~9隨機(jī)數(shù)
  3.  random_digit_not_null():1~9的隨機(jī)數(shù)
  4.  random_int():隨機(jī)數(shù)字,默認(rèn)0~9999,可以通過設(shè)置min,max來設(shè)置
  5.  random_number():隨機(jī)數(shù)字,參數(shù)digits設(shè)置生成的數(shù)字位數(shù)
  6.  pyfloat():
  7.  left_digits=5 #生成的整數(shù)位數(shù),right_digits=2 #生成的小數(shù)位數(shù),positive=True #是否只有正數(shù)
  8.  pyint():隨機(jī)Int數(shù)字(參考random_int()參數(shù))
  9.  pydecimal():隨機(jī)Decimal數(shù)字(參考pyfloat參數(shù))

7、文本、加密類

  1.  pystr():隨機(jī)字符串
  2.  random_element():隨機(jī)字母
  3.  random_letter():隨機(jī)字母
  4.  paragraph():隨機(jī)生成一個(gè)段落
  5.  paragraphs():隨機(jī)生成多個(gè)段落
  6.  sentence():隨機(jī)生成一句話
  7.  sentences():隨機(jī)生成多句話,與段落類似
  8.  text():隨機(jī)生成一篇文章
  9.  word():隨機(jī)生成詞語(yǔ)
  10.  words():隨機(jī)生成多個(gè)詞語(yǔ),用法與段落,句子,類似
  11.  binary():隨機(jī)生成二進(jìn)制編碼
  12.  boolean():True/False
  13.  language_code():隨機(jī)生成兩位語(yǔ)言編碼
  14.  locale():隨機(jī)生成語(yǔ)言/國(guó)際 信息
  15.  md5():隨機(jī)生成MD5
  16.   null_boolean():NULL/True/False
  17.  password():隨機(jī)生成密碼,可選參數(shù):length:密碼長(zhǎng)度;special_chars:是否能使用特殊字符;digits:是否包含數(shù)字;upper_case:是否包含大寫字母;lower_case:是否包含小寫字母
  18.  sha1():隨機(jī)SHA1
  19.  sha256():隨機(jī)SHA256
  20.  uuid4():隨機(jī)UUID

8、時(shí)間信息類

  1.  date():隨機(jī)日期
  2.  date_between():隨機(jī)生成指定范圍內(nèi)日期,參數(shù):start_date,end_date
  3.  date_between_dates():隨機(jī)生成指定范圍內(nèi)日期,用法同上
  4.  date_object():隨機(jī)生產(chǎn)從1970-1-1到指定日期的隨機(jī)日期。
  5.  date_time():隨機(jī)生成指定時(shí)間(1970年1月1日至今)
  6.  date_time_ad():生成公元1年到現(xiàn)在的隨機(jī)時(shí)間
  7.  date_time_between():用法同dates
  8.  future_date():未來日期
  9.  future_datetime():未來時(shí)間
  10.  month():隨機(jī)月份
  11.  month_name():隨機(jī)月份(英文)
  12.  past_date():隨機(jī)生成已經(jīng)過去的日期
  13.  past_datetime():隨機(jī)生成已經(jīng)過去的時(shí)間
  14.  time():隨機(jī)24小時(shí)時(shí)間
  15.  timedelta():隨機(jī)獲取時(shí)間差
  16.  time_object():隨機(jī)24小時(shí)時(shí)間,time對(duì)象
  17.  time_series():隨機(jī)TimeSeries對(duì)象
  18.  timezone():隨機(jī)時(shí)區(qū)
  19.  unix_time():隨機(jī)Unix時(shí)間
  20.  year():隨機(jī)年份

9、python 相關(guān)方法

  1.  profile():隨機(jī)生成檔案信息
  2.  simple_profile():隨機(jī)生成簡(jiǎn)單檔案信息
  3.  pyiterable()
  4.  pylist()
  5.  pyset()
  6.  pystruct()
  7.  pytuple()
  8.  pydict()

可以用dir(fake),看Faker庫(kù)都可以fake哪些數(shù)據(jù),目前Faker支持近300種數(shù)據(jù),此外還支持自己進(jìn)行擴(kuò)展。

有了這些生成數(shù)據(jù)函數(shù)之后用fake對(duì)象就可以調(diào)用不同的方法生成各種數(shù)據(jù)了。

3.3 常用數(shù)據(jù)場(chǎng)景

1、構(gòu)造通訊錄記錄 

  1. from faker import Faker  
  2. fake = Faker(locale='zh_CN' 
  3. for _ in range(5):  
  4.     print('姓名:', fake.name(), ' 手機(jī)號(hào):', fake.phone_number())      
  5. # 輸出信息:  
  6. 姓名: 駱柳  手機(jī)號(hào): 18674751460  
  7. 姓名: 薛利  手機(jī)號(hào): 13046558454  
  8. 姓名: 翟麗麗  手機(jī)號(hào): 15254904803  
  9. 姓名: 宋秀珍  手機(jī)號(hào): 13347585045  
  10. 姓名: 孔桂珍  手機(jī)號(hào): 18258911504 

2、構(gòu)造信用卡數(shù)據(jù) 

  1. from faker import Faker  
  2. fake = Faker(locale='zh_CN' 
  3. print('Card Number:', fake.credit_card_number(card_type=None))  
  4. print('Card Provider:', fake.credit_card_provider(card_type=None))  
  5. print('Card Security Code:', fake.credit_card_security_code(card_type=None))  
  6. print('Card Expire:', fake.credit_card_expire())  
  7. # 輸出信息:  
  8. Card Number: 676181530350  
  9. Card Provider: Diners Club / Carte Blanche  
  10. Card Security Code: 615  
  11. Card Expire: 09/21 

3、生成個(gè)人檔案信息 

  1. from faker import Faker  
  2. fake = Faker(locale='zh_CN' 
  3. print(fake.profile())  
  4. # 輸出信息  
  5. {'job': '美術(shù)指導(dǎo)', 'company': '易動(dòng)力傳媒有限公司', 'ssn': '370703197807179500', 'residence': '廣西壯族自治區(qū)旭縣薊州東莞街L座 784064', 'current_location': (Decimal('78.3608745'), Decimal('-95.946407')), 'blood_group': 'B+', 'website': ['https://www.jiewang.org/', 'https://www.longsong.cn/', 'https://jingyong.net/', 'https://58.cn/'], 'username': 'qinqiang', 'name': '唐偉', 'sex': 'F', 'address': '新疆維吾爾自治區(qū)建華市東麗拉薩街a座 875743', 'mail': 'shenyang@hotmail.com', 'birthdate': datetime.date(2014, 4, 27)} 

 4、生成Python相關(guān)結(jié)構(gòu)信息 

  1. from faker import Faker  
  2. fake = Faker(locale='zh_CN' 
  3. print('生成Python字典: {}'.format(fake.pydict(  
  4.     nb_elements=10variable_nb_elements=True)))  # Python字典  
  5. print('生成Python可迭代對(duì)象:{}.'.format(fake.pyiterable(  
  6.     nb_elements=10variable_nb_elements=True)))   # Python可迭代對(duì)象  
  7. print('生成Python結(jié)構(gòu):{}'.format(fake.pystruct(count=1)))  # Python結(jié)構(gòu)  
  8. # 輸出信息  
  9. 成Python字典: {'論壇': 'nVcSbHlrcrhIBtwByVUM', '直接': 'drkyFUNcNxdbwYKhRLEZ', '成功': 'https://fang.cn/main/search/blog/search/', '沒有': datetime.datetime(2006, 2, 24, 15, 40, 14), '原因': 404, '作者': 'OTJjsFHQklpUvTPtLCqP'} 
  10. 生成Python可迭代對(duì)象:{1088, 'ignqbohwYRxqolLEzSti', 'http://gang.cn/main/search.php', 'zRnNYdIpPXUxEVISHbvS', 'ToZxuBetghvlPHUumAvi', 9830, 'OYAjoKeVNGhHMLgnYUAw', 970446.888, -17681479853.4069, 872236250787063.0, datetime.datetime(2017, 12, 24, 5, 58, 58), 'aRSfxiUSuMqHXvKCCkMJ'} 
  11. 生成Python結(jié)構(gòu):(['cKwOvdCEFOhCERMSMXSf'], {'只有': 'hhwGCmjkHMOUjBTDztXp'}, {'還有': {0: 'vjcNqpnRbNUUxXpgVyvh', 1: [8725, 7125, 'aTSJssAJUKpuRLcbiwyK'], 2: {0: 'RmWlFQQpVZIQkxZPfJnq', 1: 'efsUVLgeStXbCOJDuJCf', 2: ['FgZQLCRjUTmEbBdDMEPZ', 'https://min.cn/search/faq/']}}}) 

 4. 自定義Faker數(shù)據(jù)類型

如果這些數(shù)據(jù)還不夠生成數(shù)據(jù)使用,F(xiàn)aker還支持創(chuàng)建自定義的Provider生成數(shù)據(jù)。 

  1. from faker import Faker  
  2. from faker.providers import BaseProvider  
  3. # 創(chuàng)建自定義Provider  
  4. class CustomProvider(BaseProvider):  
  5.     def customize_type(self):  
  6.         return 'test_Faker_customize_type'  
  7. # 添加Provider  
  8. fake = Faker()  
  9. fake.add_provider(CustomProvider)  
  10. print(fake.customize_type()) 

是不是十分簡(jiǎn)單,以后常用的數(shù)據(jù)就可以自己創(chuàng)建Provider用自動(dòng)化的方法生成了,不僅節(jié)省了時(shí)間,復(fù)用性也變高了。

5. 總結(jié)

這些只是其中的一些常見的數(shù)據(jù),F(xiàn)aker 可以造的數(shù)據(jù)遠(yuǎn)不止這些類型。相信通過本文的介紹,大家應(yīng)該對(duì) Faker 不陌生了吧。

此外,作為一個(gè)開源的庫(kù),F(xiàn)aker的源碼是非常值得研究的,也是Python新手可以用來練開源項(xiàng)目的利器。 

 

責(zé)任編輯:龐桂玉 來源: Linux運(yùn)維
相關(guān)推薦

2022-10-09 10:11:30

Python爬蟲神器

2019-02-25 10:18:43

工具代碼測(cè)試

2023-09-13 13:32:04

數(shù)據(jù)庫(kù)開源

2023-09-06 08:19:53

2024-03-13 07:26:23

2023-09-13 06:59:07

2023-06-08 08:46:37

Motrix下載工具

2023-10-31 08:03:33

開源電子簽名組件

2021-06-09 09:52:29

開源Pyroscope代碼

2021-04-27 09:00:59

PythonAidLearning編程神器

2018-11-20 09:00:00

TiDBNewSQL數(shù)據(jù)庫(kù)

2021-06-16 11:25:59

備份命令開源

2025-03-17 09:19:45

2020-08-17 10:10:34

DockerWatchtowerLinux

2020-12-10 10:00:59

監(jiān)控Java可視化

2025-03-18 08:20:58

數(shù)據(jù)庫(kù)管理工具

2020-05-26 14:15:09

開源網(wǎng)盤 免費(fèi)

2022-04-14 11:09:17

開源項(xiàng)目搜索

2024-05-22 09:36:42

開源NET

2020-12-18 08:38:22

開源前端mitojs
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)