How to round and truncate long decimal strings in

I will have string data coming in, with 1, 2, or 3 digits preceding the decimal point, and 12 digits after the decimal point.  An example would be 12.918171615141.  I need to truncate everything past the 4th decimal digit, so that my example string would look like 12.9181.

Better yet would be if I could ROUND it properly, so that in this example I would end up with 12.9182.  But to do so, I assume I would have to move the string to a numeric variable and use a math function.  IF this is feasible, I need some sample code to handle this as well, i.e. how to properly get it into a numeric variable, then do the rounding, and get it back in to a string.  TIA
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Guy Hengel [angelIII / a3]Billing EngineerCommented:
Please check double.parse and double.tryparse
Randy PooleCommented:
Dim yv as double
yv=Math.Round(yv, 3, MidpointRounding.AwayFromZero)

Open in new window

sasllcAuthor Commented:
In this example from Randy Poole, what is the right way to get my string into the numeric variable?  If my string is named strABC, do I simply say "yv=strABC"...or what is best?  

I really do need some sample showing me how to properly get the string into a numeric variable, then do the rounding, and get it back in to a string
Kyle AbrahamsSenior .Net DeveloperCommented:
Dim yv as Double 

if Double.TryParse(strABC, out yv) then
     'strABC a valid decimal.
     yv = Math.Round(yv, 3, MidpointRounding.AwayFromZero)
     strABC = yv.ToString()
    yv = nothing
   'string improperly formated, couldn't parse as a number.
end if


Open in new window


Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Visual Basic.NET

From novice to tech pro — start learning today.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.