PHP Classes


Recommend this page to a friend!
  Classes of Yuriy Tkachenko  >  PHP Person Name Case Corrector  >  >  Download  
Role: Documentation
Content type: text/markdown
Description: Documentation
Class: PHP Person Name Case Corrector
Correct the case of personal names
Author: By
Last change:
Date: 1 year ago
Size: 6,046 bytes


Class file image Download


[![Latest Version on Packagist][ico-version]][link-packagist] [![Software License][ico-license]]( [![Build Status][ico-travis]][link-travis] [![Coverage Status][ico-scrutinizer]][link-scrutinizer] [![Quality Score][ico-code-quality]][link-code-quality] [![Total Downloads][ico-downloads]][link-downloads] [![SensioLabsInsight][ico-insight]][link-insight]

Forenames and surnames are often stored either entirely in UPPERCASE or lowercase. This package allows you to convert names into the correct case where possible. Although forenames and surnames are typically stored separately if they do appear in a single string, whitespace-separated, NameCase deals correctly with them.

Currently NameCase correctly name cases names which include any of the following:

Mc, Mac, al, el, ap, bat, ben, bin, binti, binte, da, de, das, dos, delle, della, di, du, del, der, den, ten, ter, la, le, lo, van and von.

It correctly deals with names which contain apostrophes and hyphens too.

> Warning! This is for version 2.0.x. > If you need PHP 5 compatible version, please use 1.0.x!


Via Composer

$ composer require tamtamchik/namecase


use \Tamtamchik\NameCase\Formatter;

// As a static call
Formatter::nameCase("KEITH");               // => Keith
Formatter::nameCase("LEIGH-WILLIAMS");      // => Leigh-Williams
Formatter::nameCase("MCCARTHY");            // => McCarthy
Formatter::nameCase("O'CALLAGHAN");         // => O'Callaghan
Formatter::nameCase("ST. JOHN");            // => St. John
Formatter::nameCase("VON STREIT");          // => von Streit
Formatter::nameCase("AP LLWYD DAFYDD");     // => ap Llwyd Dafydd
Formatter::nameCase("HENRY VIII");          // => Henry VIII
Formatter::nameCase("VAN DYKE");            // => van Dyke

// Or as an instance
$formatter = new Formatter();
$formatter->nameCase("LOUIS XIV");          // => Louis XIV

// Passing options
  'lazy'        => true,
  'irish'       => true,
  'spanish'     => false,
  'roman'       => true,
  'hebrew'      => true,
  'postnominal' => true,

// Or
$formatter = new Formatter(['spanish' => true]);

// Or 
    'lazy' = false, 
    'postnominal' => false

// Or even
Formatter::nameCase("VAN DYKE", ['lazy' = false]);


  • `lazy` ? Default: `true`. Do not do anything if string is already mixed case and lazy option is `true`.
  • `irish` ? Default: `true`. Correct "Mac" exceptions.
  • `spanish` ? Default: `false`. Correct `el, la` and spanish conjunctions.
  • `roman` ? Default: `true`. Correct roman numbers.
  • `hebrew` ? Default: `true`. Correct `ben, bat`.
  • `postnominal` ? Default: `true`. Correct post-nominal e.g. `PhD`.

Global function

This package used to have global function str_name_case. Now it does not have it anymore. But, if you still need to have it, use this snippet.


use Tamtamchik\NameCase\Formatter;

if ( ! function_exists('str_name_case')) {

     * Wrapper for NameCase object to be used as global function.
     * @param string $string  - string to NameCase.
     * @param array  $options - options for NameCase.
     * @return string
    function str_name_case($string, $options = [])
        return Formatter::nameCase($string, $options);

Exclude Post-Nominals


use Tamtamchik\NameCase\Formatter;


Formatter::nameCase('?ERNƯ MOST');


Please see CHANGELOG for more information what has changed recently.

Testing & Demo

$ composer tests
$ composer demo


Please see CONTRIBUTING and CONDUCT for details.


If you discover any security-related issues, please email <> instead of using the issue tracker.


This library is a port of the Perl library and owes most of its functionality to the Perl version by Mark Summerfield. I also used some solutions from Ruby version by Aaron Patterson. Any bugs in the PHP port are my fault.


Original PERL Lingua::EN::NameCase Version:

  • Copyright &copy; Mark Summerfield 1998-2014. All Rights Reserved.
  • Copyright &copy; Barbie 2014-2019. All Rights Reserved.

Ruby Version:

  • Copyright &copy; Aaron Patterson 2006. All Rights Reserved.

PHP Version:

  • [Yuri Tkachenko][link-author]
  • [All Contributors][link-contributors]


The MIT License (MIT). Please see License File for more information.

[ico-version]: [ico-license]: [ico-travis]: [ico-scrutinizer]: [ico-code-quality]: [ico-downloads]: [ico-insight]:

[link-packagist]: [link-travis]: [link-scrutinizer]: [link-code-quality]: [link-downloads]: [link-author]: [link-contributors]: ../../contributors [link-insight]:

For more information send a message to info at phpclasses dot org.