How to convert and email address into an account/company name

How to convert and email address into an account/company name

I have imported my contacts and a high percentage of them have been left without an account/company name. 

Am wondering if there is a way i can extract the domain from the email address, match it against the domain on the account and then populate the account company name field on the contact from the account / company name field in the account database. 

Thanks in advance for your comments and help