CSDN-Ada助手 2023-06-03 22:27 采纳率: 1.6%
浏览 64

关于#.net#的问题:如何使用VB.NET将表格上的多个姓名对应的成绩进行统计呢

该问题来自社区帖: https://bbs.csdn.net/topics/615711574.为符合问答规范, 该问题经过ChatGPT优化
VB.NET成绩统计问题 如何使用VB.NET将表格上的多个姓名对应的成绩进行统计呢?比如计算每个姓名对应的成绩1和成绩2的总和。 请问有什么好的实现方法吗?求解! 以下是问题相关的图片链接:

  • 写回答

2条回答 默认 最新

  • 关注

    菩薩慈悲:菩薩您的表格是Excel還是MS Word?還是其他呢?
    用VBA的話,就用 Scripting.Dictionary,在VB.NET的話,則應有類似且效能更好的Dictionary來實作,很容易的。若需詳情,俟覆再議。感恩感恩 南無阿彌陀佛

    以OLEDB、ADODB 實作

    昨天才在iT邦幫忙收到 IT 邦邦友大師菩薩的指點,才知道用Dictionary的效能較 ADO、SQL 差太多,

    我用 3 萬筆資料測試結果如下:
    1.Access : 不超過 1 秒
    2.Excel +VBA + SQL (未上色) : 12 秒
    3.Excel +VBA + SQL (上色) : 17 秒
    4.Excel +VBA (你的) : 2 分 35 秒

    因此先改用ADODB 與 OLEDB 實作看看。

    ps.以下程式碼在測試對象檔案開啟時是可以測試成功的。

    Microsoft.Jet.OLEDB.4.0 要用 .xlsMicrosoft.ACE.OLEDB.12.0 才能用 .xlsm .xlsx .xlsb …… 在不開啟原檔時,才不會出錯。

        Sub sumbyNameGroup()
            ' 設置讀取檔案路徑及連線字串
            Dim filePath As String = "C:\Users\ssz3\Documents\t.xlsb" '"your_excel_file_path"
            Dim sheetName = "工作表1"
            'Dim connString As String = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + ";Extended Properties=Excel 12.0;"
            Dim connString As String = "Provider=Microsoft.Jet.OLEDB.4.0;Excel 8.0;Database=" + filePath
    
            Dim conn As New ADODB.Connection
    
            conn.Open(connString)
    
            ' 構建 SQL 語句,選擇要操作的工作表及數據欄位
            Dim sqlStr As String = "SELECT 姓名, SUM(成績1) AS 成績1總和, SUM(成績2) AS 成績2總和 FROM [" + sheetName + "$] GROUP BY 姓名"
    
            Dim rst As New ADODB.Recordset
            rst.Open(sqlStr, conn)
    
            ' 輸出結果
            Do Until rst.EOF
                Console.WriteLine(rst.Fields("姓名").Value + " " +
                                rst.Fields("成績1總和").Value.ToString() + " " +
                                rst.Fields("成績2總和").Value.ToString())
                'Console.WriteLine(rst.Fields(0).Value + " " +
                '                rst.Fields(1).Value.ToString() + " " +
                '                rst.Fields(2).Value().ToString())
                rst.MoveNext()
            Loop
    
            rst.Close() : conn.Close()
    
        End Sub
    

        Sub sumbyNameGroup()
            ' 設置讀取檔案路徑及連線字串
            Dim filePath As String = "C:\Users\ssz3\Documents\t.xlsb" '"your_excel_file_path"
            Dim sheetName = "工作表1"
            'Dim connString As String = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + ";Extended Properties=Excel 12.0;"
            Dim connString As String = "Provider=Microsoft.Jet.OLEDB.4.0;Excel 8.0;Database=" + filePath
    
            ' 創建 OleDbConnection
            Dim conn As System.Data.OleDb.OleDbConnection = New System.Data.OleDb.OleDbConnection(connString)
    
            ' 構建 SQL 語句,選擇要操作的工作表及數據欄位
            Dim sqlStr As String = "SELECT 姓名, SUM(成績1) AS 成績1總和, SUM(成績2) AS 成績2總和 FROM [" + sheetName + "$] GROUP BY 姓名"
    
            ' 創建 OleDbDataAdapter
            Dim da As System.Data.OleDb.OleDbDataAdapter = New System.Data.OleDb.OleDbDataAdapter(sqlStr, conn)
    
            ' 創建 DataTable 物件
            Dim dt As DataTable = New DataTable()
    
            ' 執行 SQL 查詢並將查詢結果填充到 DataTable
            da.Fill(dt)
    
            ' 關閉資源
            da.Dispose()
            conn.Dispose()
    
            ' 輸出結果
            For Each row As DataRow In dt.Rows
                Console.WriteLine(row("姓名").ToString() + " " + row("成績1總和").ToString() + " " + row("成績2總和").ToString())
            Next
    
        End Sub  
    

    而若要參考ADODB組建,則須將其「內嵌Interop類型」屬性設成 False,如圖:

    img

    產出結果:

    img

    评论 编辑记录

报告相同问题?

问题事件

  • 请详细说明问题背景 6月4日
  • 创建了问题 6月3日

悬赏问题

  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了