【awesome-dotnet-core-learning】(3)-Bogus-假数据生成器
简介
Bogus一个简单而强大的假数据生成器,用于C#,F#和VB.NET.从著名的faker.js移植过来.
在测试或者需要一些虚拟的数据时,Bogus就可以派上用场了.这是一个移植自faker.js的一个.NET的库,帮助你快速生成看起来有意义的假数据.该项目已经发展很长时间了,在很多有名的项目中都有使用.
特点
- 简单而又强大的数据生成
- 内置多种假数据集(用户名,公司名,邮箱地址,地址等)
- 假数据支持本地化(如中文,日文,韩文等)
- 多种API语法:流式,非流式
- 庞大而活跃的社区
快速上手
以下示例演示了用Bogus生成一个假的用户信息例子.该用户包含以下属性:
- 名字
- 年龄
- 性别
- 公司
- 电话
创建一个.NET Core的命令行应用程序(详细步骤略)
-
使用Nuget安装Bogus:
Install-Package Bogus
-
为了输出生成的用户的信息,我们再安装著名的Json.Net:
Install-Package Newtonsoft.Json
-
在
Program.cs
中,我们先创建User的类定义:class User
{
/// <summary>
/// 名字
/// </summary>
public string Name { get; set; } /// <summary>
/// 年龄
/// </summary>
public int Age { get; set; } /// <summary>
/// 性别
/// </summary>
/// <remarks>这里使用Bogus已经定义好的性别枚举类型</remarks>
public Name.Gender Gender { get; set; } /// <summary>
/// 公司
/// </summary>
public string Company { get; set; } /// <summary>
/// 电话
/// </summary>
public string Phone { get; set; }
} -
在
Main
方法中,我们使用Bogus提供的流式API为User定义生成规则:// 用户数据生成规则
var fakerPerson = new Faker<User>("zh_CN") // 使用中文数据
.RuleFor(p => p.Name, f => f.Name.FullName()) // 随机汉字名
.RuleFor(p => p.Age, f => f.Random.Number(1, 100)) // 随机年龄(1-100岁)
.RuleFor(p => p.Gender, f => f.PickRandom<Name.Gender>()) // 随机性别
.RuleFor(p => p.Company, p => p.Company.CompanyName()) // 随机公司名称
.RuleFor(p => p.Phone, p => p.Phone.PhoneNumber("1##########")) // 随机手机号
;可以看到,Bogus内置了多种数据集,如姓名,公司和电话等,可方便的生成各种类型的假数据.更多的数据集可查阅文档Bogus API Support
-
生成数据
// 生成测试用户
var person = fakerPerson.Generate(); -
使用Json.Net输出数据
// 输出测试用户数据
string json = JsonConvert.SerializeObject(person, Formatting.Indented);
Console.WriteLine(json);输出结果:
{
"Name": "谢 擎宇",
"Age": 39,
"Gender": 0,
"Company": "展鹏, 智宸 and 思",
"Phone": "13691393533"
}