Skip to content

dan-ding/people

 
 

Repository files navigation

people

Parses names into parts. Loosely based on the Lingua-EN-NameParser Perl module.

Requirements

Requires Ruby 2.1 or higher (or equivalent). To use with 1.9 or 2.0 you'll need to install either string-scrub or scrub_rb.

How to install

Add to your application's Gemfile:

gem 'people'

And then execute:

$ bundle

Or install it:

sudo gem install people

How to use

require 'people'

np = People::NameParser.new

name = np.parse( "Matthew E Ericson" ) puts name[:parsed] puts name[:orig] puts name[:first] puts name[:last]

If name successfully parses, name[:parsed] is set to true.

Available parts are :title, :first, :middle, :last, :suffix, :first2, :middle2, :title2, :suffix2, :orig, :match_type

By default, it will try to proper case names. If you want to leave the capitalization alone, pass :case_mode => 'leave' or for uppercase, 'upper'.

np = People::NameParser.new( :case_mode => 'proper' ) np = People::NameParser.new( :case_mode => 'leave' ) np = People::NameParser.new( :case_mode => 'upper' )

If you have names like "John and Jane Doe", pass :couples => true

np = People::NameParser.new( :couples => true, :case_mode => 'upper' )

name = np.parse( "John and Jane Doe" ) puts name[:first] puts name[:first2] puts name[:last]

Try it out online at http://people.ericson.net

Send suggestions to mericson at ericson dot net.

Acknowledgements

@perryjg @musicglue @stringsn88keys

Copyright

Copyright (c) 2009 Matthew Ericson. See LICENSE for details.

About

Matts Name Parser

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 100.0%