【导读】:开发项目的时,为了测试常需要造假数据,经常要尽量的模拟真实环境,通常要费大量手工而且造出来的数据,而且通常手工造出来的看起来也很别扭,费时又费事,有没有更好的办法?有,这里给大家介绍一个“专业造数“库Faker,满足你对模拟数据的所有需求。
--- 以下是正文 ---
项目开发初期,为了测试方便,我们总要造不少假数据到系统中,尽量模拟真实环境。比如要创建一批用户名,创建一段文本,电话号码,街道地址、IP地址等等。平时我们基本是键盘一顿乱敲,随便造个什么字符串出来,当然谁也不认识谁。现在你不要这样做了,用Faker就能满足你的一切需求。
【python学习交流群】
1、安装
pip install Faker
2、简单使用
>>> from faker import Faker>>> fake = Faker(locale='zh_CN')>>> fake.name'李洁'>>> fake.address'上海市兴安盟县江北东莞路r座 803484'
参数 locale:为生成数据的文化选项(语种),默认为 en_US,只有使用了相关文化,才能生成相对应的随机信息
常见的文化选项:
-
zh_CN - Chinese (China Mainland)
-
zh_TW - Chinese (China Taiwan)
-
en_US - English (United States)
3、其他方法
3.1 地理信息类
city_suffix:市,县country:国家country_code:国家编码district:区geo_coordinate:地理坐标latitude:地理坐标(纬度)longitude:地理坐标(经度)postcode:邮编province:省份address:详细地址street_address:街道地址street_name:街道名street_suffix:街、路
3.2 基础信息类
ssn:生成身份证号bs:随机公司服务名company:随机公司名(长)company_prefix:随机公司名(短)company_suffix:公司性质,如'信息有限公司'credit_card_expire:随机信用卡到期日,如'03/30'credit_card_full:生成完整信用卡信息credit_card_number:信用卡号credit_card_provider:信用卡类型credit_card_security_code:信用卡安全码job:随机职位first_name_female:女性名first_name_male:男性名name:随机生成全名name_female:男性全名name_male:女性全名phone_number:随机生成手机号phonenumber_prefix:随机生成手机号段,如139
3.3 邮箱信息类
ascii_company_email:随机ASCII公司邮箱名ascii_email:随机ASCII邮箱:company_email:公司邮箱email:普通邮箱safe_email:安全邮箱
3.4 网络基础信息类
domain_name:生成域名domain_word:域词(即,不包含后缀)ipv4:随机IP4地址ipv6:随机IP6地址mac_address:随机MAC地址tld:网址域名后缀(.com,.net.cn,等等,不包括.)uri:随机URI地址uri_extension:网址文件后缀uri_page:网址文件(不包含后缀)uri_path:网址文件路径(不包含文件名)url:随机URL地址user_name:随机用户名image_url:随机URL地址
3.5 浏览器信息类
chrome:随机生成Chrome的浏览器user_agent信息firefox:随机生成FireFox的浏览器user_agent信息internet_explorer:随机生成IE的浏览器user_agent信息opera:随机生成Opera的浏览器user_agent信息safari:随机生成Safari的浏览器user_agent信息linux_platform_token:随机Linux信息user_agent:随机user_agent信息
3.6 数字信息
numerify:三位随机数字random_digit:0~9随机数random_digit_not_:1~9的随机数random_int:随机数字,默认0~9999,可以通过设置min,max来设置random_number:随机数字,参数digits设置生成的数字位数pyfloat:随机Float数字pyint:随机Int数字(参考random_int()参数)pydecimal:随机Decimal数字(参考pyfloat参数)
3.7 文本加密类
pystr:随机字符串random_element:随机字母random_letter:随机字母paragraph:随机生成一个段落paragraphs:随机生成多个段落sentence:随机生成一句话sentences:随机生成多句话,与段落类似text:随机生成一篇文章word:随机生成词语words:随机生成多个词语,用法与段落,句子,类似binary:随机生成二进制编码boolean:True/Falselanguage_code:随机生成两位语言编码locale:随机生成语言/国际 信息md5:随机生成MD5_boolean:/True/Falsepassword:随机生成密码,可选参数:length:密码长度;special_chars:是否能使用特殊字符;digits:是否包含数字;upper_case:是否包含大写字母;lower_case:是否包含小写字母sha1:随机SHA1sha256:随机SHA256uuid4:随机UUID
4、实战使用
在数据库建一张表,通过Faker造数据,插入到表中。并且打印Faker造的数据。
import pymysqlfrom faker import Fakerconn = pymysql.connect(host="114.215.129.166", port=3306, user="nice", password="", db="flask201", charset="utf8")cursor = conn.cursorsql1 = """drop table if exists faker_user"""sql2 = """create table faker_user(pid int primary key auto_increment,username varchar(20),password varchar(20),address varchar(35) )"""cursor.execute(sql1)cursor.execute(sql2)fake = Faker("zh-CN")for i in range(20): sql = """insert into faker_user(username,password,address) values('%s','%s','%s')""" % (fake.name, fake.password(special_chars=False), fake.address) print('姓名:'+fake.name + '|密码:'+fake.password(special_chars=False) + '|地址:'+fake.address) cursor.execute(sql)conn.commitcursor.closeconn.close
输出的结果如下:
姓名:王平|密码:iZqPxLO947|地址:吉林省莉市房山杨路R座 491718姓名:柏倩|密码:h853B0idne|地址:辽宁省玉华县蓟州永安街g座 205585姓名:贾俊|密码:UsRtGXAv9o|地址:湖北省石家庄市大兴傅街c座 861094姓名:梁丹|密码:ke7QZBdBC3|地址:湖南省太原市璧山太原街m座 939225姓名:丁燕|密码:Ee9Gt9Jh5E|地址:云南省颖县海港梁街A座 403237姓名:余敏|密码:d2KhMqlen0|地址:江西省晶市城北深圳路E座 683731姓名:朱冬梅|密码:aGpEzKJZ2a|地址:台湾省建市淄川张家港路F座 443320姓名:韦小红|密码:ZDZXzsWiJ1|地址:河北省桂荣市朝阳贺街R座 559885姓名:蓝艳|密码:tvDugIUra3|地址:湖北省西宁市和平李路n座 365745姓名:黎雪|密码:Is1U1UAu57|地址:香港特别行政区六盘水市六枝特洪街e座 507272姓名:刘利|密码:8zzbAEowYA|地址:辽宁省巢湖县西夏台北街k座 665328姓名:董波|密码:q9TGizssrV|地址:台湾省桂芝市长寿大冶路v座 842339姓名:刘志强|密码:Za9Vzdocki|地址:湖南省梅市门头沟梧州街r座 897061姓名:涂飞|密码:9JFvmsO0r2|地址:辽宁省金凤市海港曾路z座 577420姓名:仲秀英|密码:6MJXQ1w6qb|地址:贵州省淑英市朝阳蔡路r座 880809姓名:赵冬梅|密码:7oUoUrw22Z|地址:湖北省斌市黄浦阜新路f座 635086姓名:张丽丽|密码:5DnZJhfnnB|地址:香港特别行政区秀芳县高坪李路b座 543520姓名:徐燕|密码:6WbRXyiY2R|地址:河北省惠州市锡山南宁路T座 266905姓名:卫帅|密码:0XqEZPbiGZ|地址:贵州省福州县浔阳孙路L座 535933姓名:李桂英|密码:6hLMsaqSI1|地址:重庆市辽阳市华龙姬街k座 718930