[VB.NET]如何在Datagridview中进行列间的计算?
来源:互联网 发布:linux 查看网络端口 编辑:程序博客网 时间:2024/06/05 11:54
<script type="text/javascript"><!--google_ad_client = "pub-8333940862668978";/* 728x90, 创建于 08-11-30 */google_ad_slot = "4485230109";google_ad_width = 728;google_ad_height = 90;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
如何在Datagridview中进行列间的计算?
举例:
Datagridview有三列,分别是price、quaty、sum
我想设置成sum=price*quaty
在论坛搜了一下贴,发现类似的问题不少,但我还是没有解决,请知道的兄弟指教,多谢
__________________________________________________________________________
具体困难在哪儿?
__________________________________________________________________________
我是由VFP刚转VB.NET的,在VFP中处理很简单:
replace sum with price*quaty
但在VB.net中,我不知道如何写这个代码
看过论坛里的一些贴子,有兄弟说在后台用SQL语句搞掂,但问题是我的datagridview的数据源是一个临时的Datatable,和后台没关啊。
楼上的兄弟,能否指教一二,感激啊!
__________________________________________________________________________
指教不敢当,呵呵。其实很简单,就是把前两项的数据相乘,放到第三项中。您只要会操作单元格中的数据自然就会了。写的潦草,还望见谅。
Public Class Form1
Dim conn As Data.OleDb.OleDbConnection
Dim da As Data.OleDb.OleDbDataAdapter
Dim ds As Data.DataSet
Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
DataGridView1.AllowUserToOrderColumns = False
conn = New OleDb.OleDbConnection( Provider=Microsoft.Jet.OleDb.4.0;Data Source=D:/data.mdb ) 假设表中有两项: price 和 quaty
conn.Open()
da = New OleDb.OleDbDataAdapter( SELECT * FROM 表1 , conn)
ds = New Data.DataSet
da.Fill(ds)
conn.Close()
DataGridView1.DataSource = ds.Tables(0)
DataGridView1.Columns.Add( sum , sum ) 加入一项 sum
For i As Int32 = 0 To DataGridView1.Rows.Count - 1
DataGridView1.Rows(i).Cells(2).Value = DataGridView1.Rows(i).Cells(0).Value * DataGridView1.Rows(i).Cells(1).Value 把前两项的数据相乘,放到第三项中
Next
End Sub
End Class
__________________________________________________________________________
可以在sql语句里相办法
select price、quaty、price*quaty as sum from ....
__________________________________________________________________________
在DataGridView的CellEndEdit事件中加入以下代码即可:
Private Sub dgrd4_CellEndEdit(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles dgrd4.CellEndEdit
Try
If Me.dgrd4.Rows(e.RowIndex).IsNewRow = False Then
If IsNumeric(Me.dgrd4.Rows(e.RowIndex).Cells( Price ).Value) = False Then
Me.dgrd4.Rows(e.RowIndex).Cells( Price ).Value = Math.Round(0, 2)
End If
If IsNumeric(Me.dgrd4.Rows(e.RowIndex).Cells( quaty ).Value) = False Then
Me.dgrd4.Rows(e.RowIndex).Cells( quaty ).Value = Math.Round(0, 2)
End If
Me.dgrd4.Rows(e.RowIndex).Cells( sum ).Value = Math.Round(Me.dgrd4.Rows(e.RowIndex).Cells( Price ).Value * Me.dgrd4.Rows(e.RowIndex).Cells( quaty ).Value, 2)
End If
End If
End If
Catch ex As Exception
MsgBox(ex.ToString, MsgBoxStyle.Critical + MsgBoxStyle.OkOnly)
End Try
__________________________________________________________________________
谢谢magicbacon(Cannot help coding)!
我要的就是:
For i As Int32 = 0 To DataGridView1.Rows.Count - 1
DataGridView1.Rows(i).Cells(2).Value = DataGridView1.Rows(i).Cells(0).Value * DataGridView1.Rows(i).Cells(1).Value 把前两项的数据相乘,放到第三项中
Next
感谢!散分
__________________________________________________________________________
也谢谢天地男儿!也是一正确方法!倦怠兄弟的办法我暂时没法用,S因为我在帖子里说了我没法到后台用SQL语句处理,不过,一并谢过了!我要多跟各位学习交流!
__________________________________________________________________________
如何在Datagridview中进行列间的计算?
举例:
Datagridview有三列,分别是price、quaty、sum
我想设置成sum=price*quaty
在论坛搜了一下贴,发现类似的问题不少,但我还是没有解决,请知道的兄弟指教,多谢
__________________________________________________________________________
具体困难在哪儿?
__________________________________________________________________________
我是由VFP刚转VB.NET的,在VFP中处理很简单:
replace sum with price*quaty
但在VB.net中,我不知道如何写这个代码
看过论坛里的一些贴子,有兄弟说在后台用SQL语句搞掂,但问题是我的datagridview的数据源是一个临时的Datatable,和后台没关啊。
楼上的兄弟,能否指教一二,感激啊!
__________________________________________________________________________
指教不敢当,呵呵。其实很简单,就是把前两项的数据相乘,放到第三项中。您只要会操作单元格中的数据自然就会了。写的潦草,还望见谅。
Public Class Form1
Dim conn As Data.OleDb.OleDbConnection
Dim da As Data.OleDb.OleDbDataAdapter
Dim ds As Data.DataSet
Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
DataGridView1.AllowUserToOrderColumns = False
conn = New OleDb.OleDbConnection( Provider=Microsoft.Jet.OleDb.4.0;Data Source=D:/data.mdb ) 假设表中有两项: price 和 quaty
conn.Open()
da = New OleDb.OleDbDataAdapter( SELECT * FROM 表1 , conn)
ds = New Data.DataSet
da.Fill(ds)
conn.Close()
DataGridView1.DataSource = ds.Tables(0)
DataGridView1.Columns.Add( sum , sum ) 加入一项 sum
For i As Int32 = 0 To DataGridView1.Rows.Count - 1
DataGridView1.Rows(i).Cells(2).Value = DataGridView1.Rows(i).Cells(0).Value * DataGridView1.Rows(i).Cells(1).Value 把前两项的数据相乘,放到第三项中
Next
End Sub
End Class
__________________________________________________________________________
可以在sql语句里相办法
select price、quaty、price*quaty as sum from ....
__________________________________________________________________________
在DataGridView的CellEndEdit事件中加入以下代码即可:
Private Sub dgrd4_CellEndEdit(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles dgrd4.CellEndEdit
Try
If Me.dgrd4.Rows(e.RowIndex).IsNewRow = False Then
If IsNumeric(Me.dgrd4.Rows(e.RowIndex).Cells( Price ).Value) = False Then
Me.dgrd4.Rows(e.RowIndex).Cells( Price ).Value = Math.Round(0, 2)
End If
If IsNumeric(Me.dgrd4.Rows(e.RowIndex).Cells( quaty ).Value) = False Then
Me.dgrd4.Rows(e.RowIndex).Cells( quaty ).Value = Math.Round(0, 2)
End If
Me.dgrd4.Rows(e.RowIndex).Cells( sum ).Value = Math.Round(Me.dgrd4.Rows(e.RowIndex).Cells( Price ).Value * Me.dgrd4.Rows(e.RowIndex).Cells( quaty ).Value, 2)
End If
End If
End If
Catch ex As Exception
MsgBox(ex.ToString, MsgBoxStyle.Critical + MsgBoxStyle.OkOnly)
End Try
__________________________________________________________________________
谢谢magicbacon(Cannot help coding)!
我要的就是:
For i As Int32 = 0 To DataGridView1.Rows.Count - 1
DataGridView1.Rows(i).Cells(2).Value = DataGridView1.Rows(i).Cells(0).Value * DataGridView1.Rows(i).Cells(1).Value 把前两项的数据相乘,放到第三项中
Next
感谢!散分
__________________________________________________________________________
也谢谢天地男儿!也是一正确方法!倦怠兄弟的办法我暂时没法用,S因为我在帖子里说了我没法到后台用SQL语句处理,不过,一并谢过了!我要多跟各位学习交流!
__________________________________________________________________________
- [VB.NET]如何在Datagridview中进行列间的计算?
- [VB.NET]如何在DataGridView中实现多列排序?大于2列的,可以有很多列的排序?(急)
- [VB.NET]请问如何在datagridview中插入button
- VB.net | 如何在程序中执行用户脚本以及进行代数式计算
- 在vb.net中关于datagridview的一些操作
- VB.Net程序设计:在DataGridView附加多列显示CombBox控件的代码段。
- [VB.NET]在vb.net中怎样来改变datagridview上一行的颜色??
- [VB.NET]如何在DataGridView控件中增加、删除和修改记录(用程序代码的方法)
- [VB.NET]如何在程序启动后让视图正好显示datagridview的最后一行?
- Vb.Net程序设计:一个DataGridView的几个列要在隐藏和显示之间切换用到的3种代码
- VB.net 如何判断DataGridView中没有选中元素
- 解决:VB.NET程序中 datagridview 多次绑定出现 的“不能在数据绑定的 DataGridView 控件上设置 ColumnCount
- VB.NET中DataGridView控件
- [VB.NET]如何捕捉datagridview控件中combox内容改变的事件?
- DataGridView中如何在textbox列中限制输入。
- 计算DataGridView列的和
- 在VB.NET中进行抓屏
- [VB.NET]DATAGRIDVIEW如何赋值入下面的两个TEXTBOX
- DirectX的一点小知识
- 控件工具栏不能自动弹出怎么办
- 基于Hibernate3.2 Hibernate tools 的使用
- 文本安装everest linux
- Hibernate常见的20个问题
- [VB.NET]如何在Datagridview中进行列间的计算?
- [VB.NET]VB2005中有Table控件吗?
- [VB.NET]如何将DataGridView中的数据存入Excel文件中?
- [VB.NET]TabControl与DataGridView能并用吗 求助
- [VB.NET]送分问题!!!我在窗体上利用鼠标动态的画矩形,就像QQ截图的矩形选框那样.可是怎么清除之前画的矩形留下的痕迹?
- 微软虚拟机Server 2008 Hyper-V
- ARM920T协处理器(CP15)指令表
- [VB.NET]菜鸟求助:运行代码错误?
- [VB.NET]用WebRequest,WebResponse,获取网页源代码,还可以更快吗?