Module: FullContact::Client::Name
- Included in:
- FullContact::Client
- Defined in:
- lib/fullcontact/client/name.rb
Overview
Public: Various methods related to name of the person
Instance Method Summary collapse
-
#deduce_by_email(email) ⇒ Object
Public: Attempts to deduce a structured name from email address.
-
#deduce_by_username(username) ⇒ Object
Public: Attempts to deduce a structured name from username.
-
#normalize(query) ⇒ Object
Public: Takes quasi structured name data provided as a string and outputs the data in a structured manner.
-
#parse(name) ⇒ Object
Public: The Name Parser method can be used when you have two names but don’t know which one is the first name and which is the last name.
-
#similarity(name_one, name_two) ⇒ Object
Public: The Name Similarity endpoint compares two names, given as the parameters q1 and q2, and returns a score indicating how similar they are.
-
#stats_by_family_name(family_name) ⇒ Object
Public: The method can be used when you know that the name is a family name (last name).
-
#stats_by_given_and_family_name(given_name, family_name) ⇒ Object
Public: The method can be use when you know both first name and last name of the person.
-
#stats_by_given_name(given_name) ⇒ Object
Public: The method can be used when you know that the name is a given name (first name).
-
#stats_by_name(name) ⇒ Object
Public: The method can be used when you only know a single name and you are uncertain whether it is the given name or family name.
Instance Method Details
#deduce_by_email(email) ⇒ Object
Public: Attempts to deduce a structured name from email address. It also returns a likelihood based on US population data. This method is ideal for business email addresses due to the use of standard convention in corporate email address formats.
email - email parameter allows to pass an email address as String
Example
deduced = FullContact.deduce_by_email('[email protected]')
# 'deduced' contains deduced contact
Returns deduced contact
36 37 38 39 |
# File 'lib/fullcontact/client/name.rb', line 36 def deduce_by_email(email) = {:email => email} get('name/deducer', ) end |
#deduce_by_username(username) ⇒ Object
Public: Attempts to deduce a structured name from username. It also returns a likelihood based on US population data.
email - username parameter allows to pass username as String
Example
deduced = FullContact.deduce_by_username('johndsmith79')
# 'deduced' contains deduced contact
Returns deduced contact
52 53 54 55 |
# File 'lib/fullcontact/client/name.rb', line 52 def deduce_by_username(username) = {:username => username} get('name/deducer', ) end |
#normalize(query) ⇒ Object
Public: Takes quasi structured name data provided as a string and outputs the data in a structured manner.
query - Query parameter allows you to pass a quasi-structured full
name String which can include standard prefix, first name,
nickname, middle name, last name and suffix.
Example
normalized = FullContact.normalize('John Smith')
# 'normalized' contains normalized contact
Returns normalized contact
18 19 20 21 |
# File 'lib/fullcontact/client/name.rb', line 18 def normalize(query) = {:q => query} get('name/normalizer', ) end |
#parse(name) ⇒ Object
Public: The Name Parser method can be used when you have two names but don’t know which one is the first name and which is the last name.
name - String name parameter allows you to pass an ambiguious name and
determine what the given name and family name is.
Example
parsed = FullContact.parse('Smith Jon')
# 'parsed' contains parsed contact
Returns parsed contact
160 161 162 163 |
# File 'lib/fullcontact/client/name.rb', line 160 def parse(name) = {:q => name} get('name/parser', ) end |
#similarity(name_one, name_two) ⇒ Object
Public: The Name Similarity endpoint compares two names, given as the parameters q1 and q2, and returns a score indicating how similar they are. As the performance of different similarity algorithms can vary over different data sets, the endpoint provides 3 separate choices.
name_one - String first name to compare name_two - String second name to compare
Example
similarity = FullContact.similarity('john','johnathan')
# 'normalized' contains similarity of contact
Returns similarity in the contact
71 72 73 74 75 76 77 |
# File 'lib/fullcontact/client/name.rb', line 71 def similarity(name_one, name_two) = { :q1 => name_one, :q2 => name_two } get('name/similarity', ) end |
#stats_by_family_name(family_name) ⇒ Object
Public: The method can be used when you know that the name is a family name (last name).
family_name - String family name of the person
Example
stats = FullContact.stats_by_family_name('smith')
# 'stats' contains stats about the contact
Returns stats about the contact
123 124 125 126 |
# File 'lib/fullcontact/client/name.rb', line 123 def stats_by_family_name(family_name) = {:familyName => family_name} get('name/stats', ) end |
#stats_by_given_and_family_name(given_name, family_name) ⇒ Object
Public: The method can be use when you know both first name and last name of the person
given_name - String first name of the person family_name - String last name of the person
Example
stats = FullContact.stats_by_given_and_family_name('john', 'smith')
# 'stats' contains stats about the contact
Returns stats about the contact
140 141 142 143 144 145 146 |
# File 'lib/fullcontact/client/name.rb', line 140 def stats_by_given_and_family_name(given_name, family_name) = { :givenName => given_name, :familyName => family_name } get('name/stats', ) end |
#stats_by_given_name(given_name) ⇒ Object
Public: The method can be used when you know that the name is a given name (first name).
given_name - String parameter allows to pass given_name of the person
Example
stats = FullContact.stats_by_given_name('john')
# 'stats' contains stats about the contact
Returns stats about the contact
107 108 109 110 |
# File 'lib/fullcontact/client/name.rb', line 107 def stats_by_given_name(given_name) = {:givenName => given_name} get('name/stats', ) end |
#stats_by_name(name) ⇒ Object
Public: The method can be used when you only know a single name and you are uncertain whether it is the given name or family name.
name - String first name or last name of person about which you are
uncertain.
Example
stats = FullContact.stats_by_name('John')
# 'stats' contains stats about the contact
Returns stats about the contact
91 92 93 94 |
# File 'lib/fullcontact/client/name.rb', line 91 def stats_by_name(name) = {:name => name} get('name/stats', ) end |