ad5jp / nanashino-gonbei
1.1.0
2023-01-21 12:47 UTC
Requires
- php: >=7.4
- ext-mbstring: *
Requires (Dev)
- phpstan/phpstan: ^1.9
- phpunit/phpunit: ^7.5
README
这是一个可以随机生成自然日本人名字的库。
可以生成的姓氏有100万种以上。
非常适合用于生成测试数据。
功能
- 可以一次性生成汉字姓氏和假名等。
- 具有唯一模式,连续生成时不会生成重复的名字。
- 可以只生成男性名字,女性名字,也可以生成名字后判断性别。
- 可以只生成现代名字或昭和名字。
安装
composer require ad5jp/nanashino-gonbei
要求
- PHP7.4以上
使用方法
基本用法
use AD5jp\NanashinoGonbei\Nanashi; // 漢字氏名とふりがな等をまとめて生成 $nanashi = new Nanashi(); $gonbei = $nanashi->born(); echo $gonbei->fullName() . "\n"; // 田中太郎 echo $gonbei->fullName(" ") . "\n"; // 田中 太郎 echo $gonbei->fullNameKana() . "\n"; // たなかたろう echo $gonbei->fullNameKana(" ") . "\n"; // たなか たろう echo $gonbei->firstName() . "\n"; // 太郎 echo $gonbei->firstNameKana() . "\n"; // たろう echo $gonbei->lastName() . "\n"; // 田中 echo $gonbei->lastNameKana() . "\n"; // たなか echo $gonbei->sex() . "\n"; // 1:男性 2:女性 echo $gonbei->generation() . "\n"; // 1:昭和 2:今どき // 必要なものだけ生成 $nanashi = new Nanashi(); echo $nanashi->fullName() . "\n"; // 鈴木一郎 echo $nanashi->fullName(" ") . "\n"; // 佐藤 次郎 echo $nanashi->fullNameKana() . "\n"; // こばやしさぶろう echo $nanashi->fullNameKana(" ") . "\n"; // たなか しろう echo $nanashi->firstName() . "\n"; // 健二 echo $nanashi->firstNameKana() . "\n"; // けんじ echo $nanashi->lastName() . "\n"; // 伊藤 echo $nanashi->lastNameKana() . "\n"; // まつい
唯一模式
use AD5jp\NanashinoGonbei\Nanashi; // ユニークモード $nanashi = new Nanashi(); $nanashi->unique(); for ($i = 0; $i < 100; $i++) { echo $nanashi->fullName() . "\n"; // 全て違う名前が生成される } // ユニークモード(その2) $nanashi = new Nanashi(); $nanashi->unique(); for ($i = 0; $i < 100; $i++) { $gonbei = $nanashi->born(); echo $gonbei->fullName() . "\n"; // 全て違う名前が生成される } // 名字のみ、名前のみを取得する場合は、重複が発生する $nanashi = new Nanashi(); $nanashi->unique(); for ($i = 0; $i < 100; $i++) { echo $nanashi->lastName() . "\n"; // 同じ名前が生じる可能性がある }
唯一标准是汉字全名。
不会出现相同汉字不同假名的情况,但不同汉字可能会有相同假名的情况。
条件指定
use AD5jp\NanashinoGonbei\Enums\Generation; use AD5jp\NanashinoGonbei\Enums\Sex; use AD5jp\NanashinoGonbei\Nanashi; // 男性の名前だけ生成 $nanashi = new Nanashi(); $nanashi->setSex(Sex::MALE); for ($i = 0; $i < 10; $i++) { echo $nanashi->fullName() . "\n"; } // 女性の名前だけ生成 $nanashi = new Nanashi(); $nanashi->setSex(Sex::FEMALE); for ($i = 0; $i < 10; $i++) { echo $nanashi->fullName() . "\n"; } // 昭和な名前だけ生成 $nanashi = new Nanashi(); $nanashi->setGeneration(Generation::SHOWA); for ($i = 0; $i < 10; $i++) { echo $nanashi->fullName() . "\n"; } // イマドキの名前だけ生成 $nanashi = new Nanashi(); $nanashi->setGeneration(Generation::KIRAKIRA); for ($i = 0; $i < 10; $i++) { echo $nanashi->fullName() . "\n"; } // 昭和な男性の名前だけ生成 $nanashi = new Nanashi(); $nanashi->setSex(Sex::MALE); $nanashi->setGeneration(Generation::SHOWA); for ($i = 0; $i < 10; $i++) { echo $nanashi->fullName() . "\n"; }
批量生成(按50音顺序排序)
use AD5jp\NanashinoGonbei\Nanashi; // 一括生成 $nanashi = new Nanashi(); $nanashi->unique(); $gonbeis = $nanashi->group(30); foreach ($gonbeis as $gonbei) { echo $gonbei->fullName() . " : " . $gonbei->fullNameKana() . "\n"; // 50音順にソートされている }
返回已按全名(假名)排序的 Gonbei 对象数组。