Access911.net   |   a9BBS   |   OTaA System  
  搜索文章︰  
Access911歡迎您光臨  
   主頁      上傳      简体版       論壇     
設為首頁  |  加入收藏   
  
你現在的位置︰文章索引 -> 文章分類 -> ADO/DAO/ADO.NET  
 首頁|  近日更新|  下載  |  文章索引  |  搜索|  朮語|  承接工程|  
 
系統正在加載內容,請耐心等待...
 
 查詢
 窗体
 報表
 
 
 VBA
 函數
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 發布
 OA
 ASP/ASP.NET
 其他語言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用軟件
 參考文檔
 業主作品
 网友大作
 
 
友情鏈接
 access911.net
 
訪問人次
 1702032
 
站長 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 訂閱

顯示附加信息 >>>

如何對一維數組或者二維數組進行排序?

作者︰cg1  摘自︰access911.net  ︰cg1  更新日期︰2006-1-27  瀏覽人次︰

 

數組排序可以用冒泡法,也可以用 VBA 集合來實現,我這里用 ADODB.RECORDSET 的 SORT 方法在內存中直接實現。

Function SortArray()
'本函數演示用 ADODB.RECORDSET 來進行數組排序,可以是二維數組,可以是任何 ADO 支持的數據類型
'請引用 ADO

    
    Dim rs As New ADODB.Recordset
    Dim a(100) As String
    Dim b(100) As Double
    
    Randomize
    Dim i As Long
    For i = 0 To 100
        b(i) = Format(Rnd * 1000, "0.00")
        a(i) = Chr(Int(Rnd * 26) + 65) & Chr(Int(Rnd * 26) + 65) & Chr(Int(Rnd * 26) + 65)
    Next
    '以上生成了 101 個隨机文字和隨机數字
    
    '下面用 adodb.recordset 進行排序

    rs.CursorLocation = adUseClient
    rs.Fields.Append "文本", adVarChar, 255
    rs.Fields.Append "數字", adDouble
    rs.Open
    
    For i = 0 To 100
        rs.AddNew
        rs("文本") = a(i)
        rs("數字") = b(i)
        rs.Update
    Next
    
    '設定排序方法
    rs.Sort = "文本 asc,數字 desc"

    '打印出排序結果
    rs.MoveFirst
    Do Until rs.EOF
        Debug.Print rs(0) & ";" & rs(1)
        rs.MoveNext
    Loop

End Function



本站文章旨在為該問題提供解決思路及關鍵性代碼,并不能完成應該由网友自己完成的所有工作,請网友在仔細看文章并理解思路的基礎上舉一反三、靈活運用。

access911.net 原創文章,作者本人對文章保留一切權利。
如需轉載必須征得作者同意并注明本站鏈接

 

 
相關文章
     沒有手動相關文章
     如何判斷VBA中的一個數組是否已經定義其維數上限下限。
     select distinct 以後如何按指定順序排序,比如按輸入順序,而不是默認的按字母順序排序?
     新手來看︰如何設定按筆畫排序?
     如何動態定義數組大小?
 
評論
     查看或發表更多的評論,請單擊這里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期︰2000年4月2日  |  設計施工︰陳格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陳格 保留所有權利