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, 陈格 保留所有权利