详解Python中第三方库Faker


Posted in Python onSeptember 25, 2020

项目开发初期,为了测试方便,我们总要造不少假数据到系统中,尽量模拟真实环境。

比如要创建一批用户名,创建一段文本,电话号码,街道地址、IP地址等等。

平时我们基本是键盘一顿乱敲,随便造个什么字符串出来,当然谁也不认识谁。

现在你不要这样做了,用Faker就能满足你的一切需求。

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_null():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/False
language_code():随机生成两位语言编码
locale():随机生成语言/国际 信息
md5():随机生成MD5
null_boolean():NULL/True/False
password():随机生成密码,可选参数:length:密码长度;special_chars:是否能使用特殊字符;digits:是否包含数字;upper_case:是否包含大写字母;lower_case:是否包含小写字母
sha1():随机SHA1
sha256():随机SHA256
uuid4():随机UUID

3.8 时间信息类

date():随机日期
date_between():随机生成指定范围内日期,参数:start_date,end_date
date_between_dates():随机生成指定范围内日期,用法同上
date_object():随机生产从1970-1-1到指定日期的随机日期。
date_time():随机生成指定时间(1970年1月1日至今)
date_time_ad():生成公元1年到现在的随机时间
date_time_between():用法同dates
future_date():未来日期
future_datetime():未来时间
month():随机月份
month_name():随机月份(英文)
past_date():随机生成已经过去的日期
past_datetime():随机生成已经过去的时间
time():随机24小时时间
timedelta():随机获取时间差
time_object():随机24小时时间,time对象
time_series():随机TimeSeries对象
timezone():随机时区
unix_time():随机Unix时间
year():随机年份

4. 实战使用

import pymysql
from faker import Faker

conn = pymysql.connect(host="114.215.129.166", port=3306, user="nice", password="", db="flask201",
            charset="utf8")

cursor = conn.cursor()
sql1 = """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())
  cursor.execute(sql)

conn.commit()
cursor.close()
conn.close()

到此这篇关于详解Python中第三方库Faker的文章就介绍到这了,更多相关Python第三方库Faker内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
videocapture库制作python视频高速传输程序
Dec 23 Python
在Python的Django框架中生成CSV文件的方法
Jul 22 Python
Python3学习笔记之列表方法示例详解
Oct 06 Python
浅谈python numpy中nonzero()的用法
Apr 02 Python
python3+PyQt5图形项的自定义和交互 python3实现page Designer应用程序
Jul 20 Python
python实现将一个数组逆序输出的方法
Jun 25 Python
Python小白必备的8个最常用的内置函数(推荐)
Apr 03 Python
从列表或字典创建Pandas的DataFrame对象的方法
Jul 06 Python
python实现银行实战系统
Feb 26 Python
利用pandas向一个csv文件追加写入数据的实现示例
Apr 23 Python
Django基于Models定制Admin后台实现过程解析
Nov 11 Python
关于Python3的import问题(pycharm可以运行命令行import错误)
Nov 18 Python
python对批量WAV音频进行等长分割的方法实现
Sep 25 #Python
python连接mysql数据库并读取数据的实现
Sep 25 #Python
Python3如何使用tabulate打印数据
Sep 25 #Python
如何基于pandas读取csv后合并两个股票
Sep 25 #Python
matplotlib设置颜色、标记、线条,让你的图像更加丰富(推荐)
Sep 25 #Python
python实现人性化显示金额数字实例详解
Sep 25 #Python
python 绘制正态曲线的示例
Sep 24 #Python
You might like
判断PHP数组是否为空的代码
2011/09/08 PHP
php自定义的格式化时间示例代码
2013/12/05 PHP
php实现删除指定目录下相关文件的方法
2014/10/20 PHP
详解YII关联查询
2016/01/10 PHP
Javascript类定义语法,私有成员、受保护成员、静态成员等介绍
2011/12/08 Javascript
在JavaScript里嵌入大量字符串常量的实现方法
2013/07/07 Javascript
JS和jQuery使用submit方法无法提交表单的原因分析及解决办法
2016/05/17 Javascript
jquery使用on绑定a标签无效 只能用live解决
2016/06/02 Javascript
利用原生js和jQuery实现单选框的勾选和取消操作的方法
2016/09/04 Javascript
JS获取本周周一,周末及获取任意时间的周一周末功能示例
2017/02/09 Javascript
JS库particles.js创建超炫背景粒子插件(附源码下载)
2017/09/13 Javascript
浅谈Vue.js 组件中的v-on绑定自定义事件理解
2017/11/17 Javascript
webpack 单独打包指定JS文件的方法
2018/02/22 Javascript
微信小程序自定义多选事件的实现代码
2018/05/17 Javascript
JS实现求5的阶乘示例
2019/01/21 Javascript
从零搭一个自用的前端脚手架的方法步骤
2019/09/23 Javascript
Vue 实现监听窗口关闭事件,并在窗口关闭前发送请求
2020/09/01 Javascript
详解 javascript对象创建模式
2020/10/30 Javascript
python画出三角形外接圆和内切圆的方法
2018/01/25 Python
python+POP3实现批量下载邮件附件
2018/06/19 Python
详解python多线程之间的同步(一)
2019/04/03 Python
Python3.5面向对象编程图文与实例详解
2019/04/24 Python
python3.6编写的单元测试示例
2019/08/17 Python
Python进程间通信multiprocess代码实例
2020/03/18 Python
什么是命名空间(NameSpace)
2015/11/24 面试题
2013英文求职信模板范文
2013/11/15 职场文书
银行委托书范本
2014/04/04 职场文书
建筑安全标语
2014/06/07 职场文书
餐饮周年庆活动方案
2014/08/14 职场文书
银行先进个人总结
2015/02/15 职场文书
2015年办公室文员工作总结
2015/04/24 职场文书
债务纠纷代理词
2015/05/25 职场文书
好段摘抄大全(48句)
2019/08/08 职场文书
Nginx的rewrite模块详解
2021/03/31 Servers
Sql Server之数据类型详解
2022/02/28 SQL Server
利用JuiceFS使MySQL 备份验证性能提升 10 倍
2022/03/17 MySQL