PHPackages                             phpsoftbox/inflector - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. phpsoftbox/inflector

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

phpsoftbox/inflector
====================

Inflector (pluralize/singularize) for the PhpSoftBox framework

0100↓90.5%PHP

Since Apr 17Pushed 2mo agoCompare

[ Source](https://github.com/phpsoftbox/inflector)[ Packagist](https://packagist.org/packages/phpsoftbox/inflector)[ RSS](/packages/phpsoftbox-inflector/feed)WikiDiscussions master Synced 2d ago

READMEChangelogDependenciesVersions (1)Used By (0)

PhpSoftBox Inflector
====================

[](#phpsoftbox-inflector)

`phpsoftbox/inflector` — компонент для преобразования слов между единственным и множественным числом.

Компонент **вдохновлён Doctrine Inflector**, но реализован в более лёгком и прагматичном виде, чтобы:

- не тянуть лишние зависимости,
- иметь предсказуемую архитектуру под мульти-языковые ruleset'ы,
- оставаться удобным для использования в ORM/DBAL.

Установка
---------

[](#установка)

```
composer require phpsoftbox/inflector
```

Быстрый старт
-------------

[](#быстрый-старт)

```
use PhpSoftBox\Inflector\InflectorFactory;
use PhpSoftBox\Inflector\LanguageEnum;

$inflector = InflectorFactory::create(LanguageEnum::EN);

echo $inflector->pluralize('post');    // posts
echo $inflector->singularize('posts'); // post
```

Дополнительные методы (конвенции/ORM)
-------------------------------------

[](#дополнительные-методы-конвенцииorm)

Инфлектор также содержит небольшой набор утилит, часто полезных в ORM и соглашениях по именованию:

```
$inflector->tableize('BlogPost');     // blog_post
$inflector->classify('blog_post');    // BlogPost
$inflector->camelize('blog_post');    // blogPost
$inflector->capitalize('top-o-the-morning to all_of_you!'); // Top-O-The-Morning To All_of_you!
$inflector->urlize('My first blog post'); // my-first-blog-post
```

Поддержка языков
----------------

[](#поддержка-языков)

Язык выбирается через `LanguageEnum`.

Сейчас реализованы:

- `EN`
- `RU` (базовый набор rules для частых доменных слов)

```
$inflector = InflectorFactory::create(LanguageEnum::EN);
$ruInflector = InflectorFactory::create(LanguageEnum::RU);
```

Пример RU:

```
use PhpSoftBox\Inflector\InflectorFactory;
use PhpSoftBox\Inflector\LanguageEnum;

$inflector = InflectorFactory::create(LanguageEnum::RU);

echo $inflector->pluralize('миграция');   // миграции
echo $inflector->singularize('товары');   // товар
echo $inflector->pluralizeByCount(21, 'миграцию', 'миграции', 'миграций'); // миграцию
```

Склонение ФИО
-------------

[](#склонение-фио)

В языках, где поддерживается склонение имён (сейчас `RU`), доступны:

- `getNameCases(string $fullName, ?string $gender = null): array`
- `getNameCase(string $fullName, string $case, ?string $gender = null): string`
- `detectNameGender(string $fullName): ?string`

Для `EN` используется заглушка: имя возвращается без изменений, пол `null`.

```
use PhpSoftBox\Inflector\Names\Cases;

$ru = InflectorFactory::create(LanguageEnum::RU);
$en = InflectorFactory::create(LanguageEnum::EN);

echo $ru->getNameCase('Иванов Иван Иванович', Cases::GENITIVE->value);
// Иванова Ивана Ивановича

$allCases = $ru->getNameCases('Иванова Анна Ивановна');
$gender = $ru->detectNameGender('Иванова Анна Ивановна'); // f

echo $en->getNameCase('John Doe', Cases::GENITIVE->value); // John Doe
```

Как устроены правила (rules)
----------------------------

[](#как-устроены-правила-rules)

Структура rules-слоя похожа на Doctrine Inflector:

- `Pattern` — паттерн (может быть регуляркой `/.../` или строкой/regex-фрагментом).
- `Transformation` — правило замены по совпадению `Pattern`.
- `Substitution` + `Word` — "неправильные" формы (irregular).
- `Ruleset` — объединяет:
    - `Transformations` (regular)
    - `Patterns` (uninflected)
    - `Substitutions` (irregular)

Пример: английские правила располагаются в `src/Rules/En`:

- `Inflectable` — склоняемые правила (plural/singular + irregular)
- `Uninflected` — слова/паттерны, которые **не склоняются**
- `Rules` — сборка двух ruleset'ов (plural/singular)

Примеры
-------

[](#примеры)

### Irregular

[](#irregular)

```
$inflector = InflectorFactory::create(LanguageEnum::EN);

echo $inflector->pluralize('person'); // people
echo $inflector->singularize('people'); // person
```

### Uninflected + regex

[](#uninflected--regex)

Uninflected можно задавать через паттерны, включая regex:

```
$inflector = InflectorFactory::create(LanguageEnum::EN);

echo $inflector->pluralize('hardware'); // hardware
echo $inflector->pluralize('metadata'); // metadata
```

Тесты
-----

[](#тесты)

В репозитории PhpSoftBox тесты запускаются, как правило, через Makefile.

```
make select-inflector
make php-test
```

###  Health Score

22

—

LowBetter than 21% of packages

Maintenance56

Moderate activity, may be stable

Popularity12

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity12

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/0279d150240c97d210034878b0467462246dc14d29b5618157ff6a8be49a50e3?d=identicon)[inspector-who](/maintainers/inspector-who)

---

Top Contributors

[![inspector-who](https://avatars.githubusercontent.com/u/6973963?v=4)](https://github.com/inspector-who "inspector-who (1 commits)")

### Embed Badge

![Health badge](/badges/phpsoftbox-inflector/health.svg)

```
[![Health](https://phpackages.com/badges/phpsoftbox-inflector/health.svg)](https://phpackages.com/packages/phpsoftbox-inflector)
```

###  Alternatives

[halilcosdu/laravel-chatbot

Laravel AI Chatbot Package

655.6k](/packages/halilcosdu-laravel-chatbot)[netresearch/t3-cowriter

With the help of AI you can now work on a page together with a cowriter - a digital assistant that helps you to write your content.

1111.7k](/packages/netresearch-t3-cowriter)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
