Solved

Need name extraction function?

Posted on 2007-11-16
6
248 Views
Last Modified: 2013-11-07
I need some functions that will take a person's full name as a string, and attempt to extract the various piecces of it, i.e.:

GetFirstName(), GetNamePrefix(), GetMiddleName(), GetNameSuffix()

What I would pass in would be something like:
John Doe
Dr. Alvin Chipmunk Ph.D.
Miss Mary Kate O'Reily
Mr. Alberto Juan De Laurentis

I was hoping that there might be some functions out there already to handle this so I wouldn't have to re-invent the wheel? I'll take code in either C# or VB.NET, or whatever really, as long as it can be converted to .NET of some sort.
0
Comment
Question by:toddhd
  • 3
  • 2
6 Comments
 
LVL 55

Expert Comment

by:Jaime Olivares
ID: 20300189
Is is not as easy. Consider this case:
Juan Marcelo Menotti
How you will know if Marcelo is the Middle Name or it is the second first name?
A dictionary will be useless.

You can try to attack the problem by a different side. Store the name components separately:


class PersonName

{

    string Prefix;

    string FirstName;

    string MidName;

    string LastName;

    string Suffix;
 

    public string GetFirstName() { return FirstName; }

    public string GetMiddleName() { return MidName; }

    public string GetLastName() { return LastName; } 

    // etcetera
 

    public override string ToString()

   {

         StringBuilder sb = new StringBuilder();

         if (!string.IsNullOrEmpty(Prefix))

               sb.Append(Prefix+" ");

         if (!string.IsNullOrEmpty(FirstName))

               sb.Append(FirstName+" ");

         if (!string.IsNullOrEmpty(MidName))

               sb.Append(MidName+" ");

         // etcetera

    }

}

Open in new window

0
 
LVL 55

Expert Comment

by:Jaime Olivares
ID: 20300195
sorry, ToString method should end with:

    return sb.ToString();
}
0
 
LVL 8

Author Comment

by:toddhd
ID: 20300480
jaime,
I agree with you approach completely, but I just dont have that luxury :)
I have a client (a bank no less) that has some very old data in a database where the names have been entered as one long string, and well - you guessed it, they want to get the data back out.
I am working on my own function, and made up a list of prefixes I know of to check against. Postfixes are tougher as they are practically limitless, and some have periods (Ph.D., Sr. D.D.S) and some don't (such as roman numerals). At some point, I just have to make an educated guess.

The first/last name thing is an issue with non-American names, and middle names can get out of hand sometimes as well, since there can be multiple ones.
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 22

Expert Comment

by:JimBrandley
ID: 20300581
I would start with a split on blanks. You can deduce some of the structure by knowing the number of elements in the name.
string fullName = "Dr. Ralph Waldo Emerson III Esq., PhD, MD";
string[] elements = fullName.Split(' ');

Jim
0
 
LVL 55

Accepted Solution

by:
Jaime Olivares earned 500 total points
ID: 20300645
toddhd,
I have been there.
A possible approach is to make a semi-automated migration, one-by-one. Create a migration application where you suggest an interpretation and let user to choose a name structure, some UI with radio buttons  like (using Jim's example):

Full Name: Dr. Ralph Waldo Emerson III Esq., PhD, MD
 

Please correct name structure, if needed:

Dr.      (x) Prefix, ( ) First, ( ) Middle, ( ) Last, ( ) Postfix 

Ralph    ( ) Prefix, (x) First, ( ) Middle, ( ) Last, ( ) Postfix 

Waldo    ( ) Prefix, ( ) First, (x) Middle, ( ) Last, ( ) Postfix

Emerson  ( ) Prefix, ( ) First, (x) Middle, ( ) Last, ( ) Postfix 

III      ( ) Prefix, ( ) First, ( ) Middle, (x) Last, ( ) Postfix

Esq.     ( ) Prefix, ( ) First, ( ) Middle, ( ) Last, (x) Postfix

PhD      ( ) Prefix, ( ) First, ( ) Middle, ( ) Last, (x) Postfix

MD       ( ) Prefix, ( ) First, ( ) Middle, ( ) Last, (x) Postfix

Open in new window

0
 
LVL 8

Author Closing Comment

by:toddhd
ID: 31409605
jaime, I'm just going to award you the points. While it's not an exact answer, it at least tells me that I'm on the right track with what I'm doing, and that no pre-written methiod exists to do this. I'll have to post my code somewhere once I'm done so other people can use it i nthe future :)
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article describes relatively difficult and non-obvious issues that are likely to arise when creating COM class in Visual Studio and deploying it by professional MSI-authoring tools. It is assumed that the reader is already familiar with the cla…
Today I had a very interesting conundrum that had to get solved quickly. Needless to say, it wasn't resolved quickly because when we needed it we were very rushed, but as soon as the conference call was over and I took a step back I saw the correct …
This tutorial demonstrates a quick way of adding group price to multiple Magento products.
A short film showing how OnPage and Connectwise integration works.

937 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

6 Experts available now in Live!

Get 1:1 Help Now