Jump to content
Xtreme .Net Talk

Recommended Posts

Posted

Hi,

Is there a function in VB that get a string and removes the empty spaces only at left and right of the string?

I mean just remove the spaces at first and end of string?

Thanks:)

  • Leaders
Posted

Would the string.Trim function suit your purposes?


[Color=Blue]Dim[/Color] Trimmed [Color=Blue]As String [/Color]= ([Color=DarkRed]" SPACES "[/Color]).Trim() [Color=Green]'Trimmed = "SPACES"[/Color]
[/Code]

[Edit]Looks like David Anton beat me to the punch, but now I'm not sure whether you were looking to trim both the start and end at once, or only one or the other. Now we have all our bases covered, I guess.[/Edit]

[sIGPIC]e[/sIGPIC]
Posted
You can either use the .NET String methods "TrimEnd" and "TrimStart" or use the VB functions "RTrim" and "LTrim".

 

Ack - forgot "Trim" (both the .NET String class and VB have a method with this name).

Posted

But the behavior between Trim() as a method of a string and Trim() as a function inherited from VB language is different right?

 

Using the Trim() function requires the string to be pass as a parameter. marble_eater shows using the Trim() method of a string.

 

CMIIW.

Amir Syafrudin
  • Leaders
Posted

That is correct. The VB function is available mainly for backwards compatability reasons. They both basically do the same thing, but the syntax is different. Also, I'm not sure whether or not they work exactly the same. You would have to look at the documentation. Trim() works the way it did in VB6. String.Trim() works the DotNet way. There may be a difference in what they consider whitespace. They may be the same, they may not be. I don't know.

 

[Color=Blue]Dim[/Color] spaced [Color=Blue]As String [/Color]= [Color=DarkRed]"    spaced out    "[/Color]
[Color=Blue]Dim[/Color] unspaced1 [Color=Blue]As String [/Color]= Trim(spaced)
[Color=Green]' results in "spaced out"[/Color]
[Color=Blue]Dim[/Color] unspaced2 [Color=Blue]As String[/Color] = spaced.Trim()
[Color=Green]' also results in "spaced out"[/Color]

[sIGPIC]e[/sIGPIC]
Posted

One main difference between the .NET methods and the VB methods is that the VB methods will attempt to avoid exceptions at all costs.

e.g., the following assigns an empty string to s2, but results in an exception when attempting to assign to s3 (excuse the variable names):

Dim s1 As String

Dim s2 As String = Trim(s1)

Dim s3 As String = s1.Trim()

  • Leaders
Posted

I would say that that particular error is the consequence of the difference between an object oriented approach and a non-OOP approach.

 

I whipped up a quick app...


[Color=Blue]Private Sub[/Color] Form1_Load([Color=Blue]ByVal [/Color]sender [Color=Blue]As [/Color]System.Object, [Color=Blue]ByVal [/Color]e [Color=Blue]As [/Color]System.EventArgs) [Color=Blue]Handles [/Color][Color=Blue]MyBase[/Color].Load
[Color=Blue]For [/Color]i [Color=Blue]As Integer [/Color]= 0 [Color=Blue]To [/Color]255
TextBox1.AppendText((Chr(i) + i.ToString() + Chr(i)).Trim() + Environment.NewLine)
TextBox2.AppendText(Trim(Chr(i) + i.ToString() + Chr(i)) + Environment.NewLine)
[Color=Blue] Next
End Sub[/Color]
[/Code]

It seems the DotNet String.Trim() function trims [i]all whitespace[/i], while the legacy Trim() function trims only spaces.

[sIGPIC]e[/sIGPIC]
Posted
One main difference between the .NET methods and the VB methods is that the VB methods will attempt to avoid exceptions at all costs.

e.g., the following assigns an empty string to s2, but results in an exception when attempting to assign to s3 (excuse the variable names):

Dim s1 As String

Dim s2 As String = Trim(s1)

Dim s3 As String = s1.Trim()

 

Isn't the cause of the exception trying to access a method from a null object? s1 is null right?

Amir Syafrudin
Posted

VB "features"

 

Isn't the cause of the exception trying to access a method from a null object? s1 is null right?

 

Sure.

 

I know this is straying way off topic, but I think the fact that Microsoft has implemented so many of these legacy functions is one of the main detractors of VB.Net. Now we have 2 methods with similar or identical names which both behave differently. I really wish Microsoft had been strong enough to not pander to the whole backwards-compatibility crowd and actually forced people to learn how to program properly - a null reference is not the same as a null string. Most applications should be entirely rewritten when converting from VB6 to VB.Net, so the inclusion of these methods is a little unhelpful.

 

I know it sounds drastic, but I would seriously recommend any VB.Net programmers wishing to improve the quality of their code delete any references to Microsoft.VisualBasic, and start converting their code to using the standard framework classes.

Never trouble another for what you can do for yourself.
  • Leaders
Posted

Re: VB "features"

 

Well, now that we are off topic, it is easy to say that Microsoft should have had the cojones to do away with VB6 legacy functions, controls, and features that might be redundant or "encourage bad programming." It's a whole different story when you are trying to sell Visual Basic. For businesses, it is not acceptable to have to re-write entire applications. This "backwards compatability" sometimes brings porting programs into the realm of possibility.

 

I agree whole-heartedly with your recommendation to stay away from VisualBasic namespaces, but for pre-existing code there is a need for compatability and Microsoft had to try to fulfill this need in order to make the purchase more worthwhile for more customers.

[sIGPIC]e[/sIGPIC]
Posted

Re: VB "features"

 

I'd agree with marble_eater regarding backward-compatibility. But it would be so much better if Microsoft would provide backward-compatibility using the Framework instead of simply creating a general Microsoft.VisualBasic namespace. That way converting VB6 code to .Net would be as easy as always without any traces of legacy codes left in the converted code. I think this is what MrPaul is trying to say.

 

The existence of Microsoft.VisualBasic is simply for backward-compatibility right? This wouldn't go with the concept of interoperability between .Net language. Considering I'm using two language in .Net (i.e. VB and C#), I always tried my best not to use any code from Microsoft.VisualBasic.

Amir Syafrudin
  • Leaders
Posted

Re: VB "features"

 

I'd agree with marble_eater regarding backward-compatibility. But it would be so much better if Microsoft would provide backward-compatibility using the Framework instead of simply creating a general Microsoft.VisualBasic namespace. [/Quote]

That would require polluting the standard DotNet libraries with VB6 functions. I don't see any other way to get VB6 code to compile to DotNet. I think Microsoft put the legacy functions in the right place.

 

The existence of Microsoft.VisualBasic is simply for backward-compatibility right? This wouldn't go with the concept of interoperability between .Net language.

Quite a common complaint. This is why we always tell new programmers to remove all references to Microsoft.VisualBasic and Microsoft.VisualBasic.Compatability. The biggest problem is that these don't come excluded in new projects by default and Microsoft does very little to encourage programmers to migrate new the "DotNet" method of doing things.

[sIGPIC]e[/sIGPIC]

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...