Swapping values

Please support our VB.NET advertiser: Programming Forums - DaniWeb Sister Site
Thread Solved

Join Date: Mar 2009
Posts: 56
Reputation: songweaver is an unknown quantity at this point 
Solved Threads: 0
songweaver songweaver is offline Offline
Junior Poster in Training

Swapping values

 
0
  #1
Nov 3rd, 2009
Hey guys here is the problem I have two variables that need their values switched , but only if the value stored in the first is less than the value stored in the second. Tried a couple of things, but am at a brick wall, I am a newbie to VB.

  1. Public Class Form1
  2.  
  3. Private Sub btnCheck_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnCheck.Click
  4. Dim getMarySales As Integer
  5. Dim getJeffSales As Integer
  6. If getMarySales < getJeffSales Then
  7. getJeffSales = txtGetMarySales.Text
  8. getMarySales = txtGetJeffSales.Text
  9. End If
  10.  
  11.  
  12.  
  13.  
  14. End Sub
Reply With Quote Quick reply to this message  
Join Date: Oct 2009
Posts: 63
Reputation: mikiurban is an unknown quantity at this point 
Solved Threads: 17
mikiurban mikiurban is offline Offline
Junior Poster in Training
 
0
  #2
Nov 3rd, 2009
In line 6, you are comparing your newly created integers, which are both 0. You need to either assign them the values from the text box before the comparison, or compare the textbox values themselves (I suggest the assignment).

You should also be having a problem assigning the textbox values to the integers themselves, because textboxes not integers. You will probably want to throw a couple Int32.Parse() calls in there to convert them to integers.
Reply With Quote Quick reply to this message  
Join Date: Mar 2009
Posts: 56
Reputation: songweaver is an unknown quantity at this point 
Solved Threads: 0
songweaver songweaver is offline Offline
Junior Poster in Training

Reply

 
0
  #3
Nov 4th, 2009
How would I compare textbox values because if I assign values, b/c if I assign textbox values, the users couldn't enter their own, right? Please excuse my ignorance if I am wrong and please explain to me how to do that. Also I looked at the parse and see if this would be correct.

  1. Public Class Form1
  2.  
  3. Private Sub btnCheck_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnCheck.Click
  4.  
  5. Dim getMarySales As Integer = txtGetMarySales.Text
  6. Int32.Parse(getMarySales)
  7. Dim getJeffSales As Integer = txtGetJeffSales.Text
  8. Int32.Parse(getJeffSales)
  9. If getMarySales < getJeffSales Then
  10. getJeffSales = txtGetMarySales.Text
  11. getMarySales = txtGetJeffSales.Text
  12. End If
  13. End Sub
  14. End Class
Originally Posted by mikiurban View Post
In line 6, you are comparing your newly created integers, which are both 0. You need to either assign them the values from the text box before the comparison, or compare the textbox values themselves (I suggest the assignment).

You should also be having a problem assigning the textbox values to the integers themselves, because textboxes not integers. You will probably want to throw a couple Int32.Parse() calls in there to convert them to integers.
Last edited by songweaver; Nov 4th, 2009 at 1:32 pm.
Reply With Quote Quick reply to this message  
Join Date: Oct 2009
Posts: 63
Reputation: mikiurban is an unknown quantity at this point 
Solved Threads: 17
mikiurban mikiurban is offline Offline
Junior Poster in Training
 
0
  #4
Nov 4th, 2009
You don't need to set the textbox values to anything, just sompare them.

Then changes you made are almost complete, but change this
  1. Dim getMarySales As Integer = txtGetMarySales.Text
  2. Int32.Parse(getMarySales)
to
  1. Dim getMarySales As Integer = Int32.Parse(txtGetMarySales.Text)
(and the other one, too, as well as the ones after the comparison.)

There are several ways to write this section of code, and all will end up with the same result: your two variables holding the proper values. If you want to make your code more bulletproof, you can use Int32.TryParse() to handle problems when someone enters a non-number or decimal point in the textboxes. Also, instead of parsing the numbers twice, you can use a temp variable to help you swap the already calculated values (you will probably get an assignment later to write a Swap function like this:
  1. Dim temp As Integer = a
  2. a = b
  3. b = temp
Reply With Quote Quick reply to this message  
Join Date: Mar 2009
Posts: 56
Reputation: songweaver is an unknown quantity at this point 
Solved Threads: 0
songweaver songweaver is offline Offline
Junior Poster in Training

Close

 
0
  #5
Nov 4th, 2009
I am close getting it to work like this, however when the value jeffSales is greater than marySales it shows false not switch to the jeff value.

  1. Public Class Form1
  2.  
  3. Private Sub btnCheck_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnCheck.Click
  4.  
  5. Dim getMarySales As Integer = txtGetMarySales.Text
  6. Int32.Parse(getMarySales)
  7. Dim getJeffSales As Integer = txtGetJeffSales.Text
  8. Int32.Parse(getJeffSales)
  9. If getMarySales < getJeffSales Then
  10. txtGetMarySales.Text = txtGetJeffSales.Text AndAlso _
  11. txtGetJeffSales.Text = txtGetMarySales.Text
  12. End If
  13. End Sub
Reply With Quote Quick reply to this message  
Join Date: Oct 2009
Posts: 63
Reputation: mikiurban is an unknown quantity at this point 
Solved Threads: 17
mikiurban mikiurban is offline Offline
Junior Poster in Training
 
0
  #6
Nov 4th, 2009
In your If block, you are swapping the values of text boxes, but not the values of the variables. Did you just want the values of the textboxes swapped?
Reply With Quote Quick reply to this message  
Join Date: Mar 2009
Posts: 56
Reputation: songweaver is an unknown quantity at this point 
Solved Threads: 0
songweaver songweaver is offline Offline
Junior Poster in Training
 
0
  #7
Nov 4th, 2009
I guess that would be correct, yes because the values showing up in the text boxes need to be switched.
Originally Posted by mikiurban View Post
In your If block, you are swapping the values of text boxes, but not the values of the variables. Did you just want the values of the textboxes swapped?
Reply With Quote Quick reply to this message  
Join Date: Mar 2009
Posts: 56
Reputation: songweaver is an unknown quantity at this point 
Solved Threads: 0
songweaver songweaver is offline Offline
Junior Poster in Training

Reply

 
0
  #8
Nov 4th, 2009
Any help with how to make them switch without it showing false in 1st textbox?
Reply With Quote Quick reply to this message  
Reply

This thread has been marked solved.
Perhaps start a new thread instead?
Message:




Views: 245 | Replies: 7
Thread Tools Search this Thread



Tag cloud for VB.NET
About Us | Contact Us | Advertise | DaniWeb | Acceptable Use Policy | RSS Feed

©2003 - 2009 DaniWeb® LLC