微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

[VB.NET]如何在Datagridview中进行列间的计算?

如何在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语句处理,不过,一并谢过了!我要多跟各位学习交流! __________________________________________________________________________

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr