设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 3987|回复: 3
打印 上一主题 下一主题

[模块/函数] 【Access小品】中心开花--自定义函数编制讲座二

[复制链接]
跳转到指定楼层
1#
发表于 2011-4-28 06:41:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 todaynew 于 2011-4-28 20:28 编辑

  编写自定义函数时,一般需要找到所需功能的核心算法,这个算法可先从一个特例开始进行编写。中心开花,逐步抽象,递次外延,直到获得满足功能需求的完整代码。下面以版友123xiaoniu同志昨日所问字符串排序问题为例,说明函数编写的过程。

第一步 先做字符串第一位的排序,基本思路为:将第一位的字符顺序向后逐个比较,取得最小值的字符,并将其排列到第一位。那么函数可写为:

Function OrderStr(str As String) As String
Dim s As String
Dim j As Long
Dim n As Long
s = Mid(str, 1, 1)
For j = 1 To Len(str)
      If Mid(str, j, 1) < s Then s = Mid(str, j, 1): n = j '计算最小值及其位置。
Next
str = s & Replace(str, s, "", 1, 1) '排序
OrderStr = str
End Function

第二步 做第一位到倒数第二位的循环比较排序。函数可写为:
Function OrderStr(str As String) As String
Dim s As String
Dim i As Long, j As Long
Dim n As Long
For i = 1 To Len(str) - 1
    s = Mid(str, i, 1)
    For j = i + 1 To Len(str)
        If Mid(str, j, 1) < s Then s = Mid(str, j, 1): n = j
    Next
    str = Mid(str, 1, i - 1) & s & Replace(str, s, "", i, 1)
Next
OrderStr = str
End Function

第三步 做可选择顺序和逆序的排序函数
Function OrderStr(str As String, B As Long) As String
'功能:字符串排序
'参数:str--源字符串,B=1 降序 B=2 升序
Dim s As String
Dim i As Long, j As Long
Dim n As Long
For i = 1 To Len(str) - 1
    s = Mid(str, i, 1)
    For j = i + 1 To Len(str)
        Select Case B
            Case 1
                If Mid(str, j, 1) < s Then s = Mid(str, j, 1): n = j
            Case 2
                If Mid(str, j, 1) > s Then s = Mid(str, j, 1): n = j
        End Select
    Next
    str = Mid(str, 1, i - 1) & s & Replace(str, s, "", i, 1)
Next
OrderStr = str
End Function







本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

本帖被以下淘专辑推荐:

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享分享 分享淘帖1 订阅订阅
2#
发表于 2011-4-28 08:20:41 | 只看该作者
todaynew 老师谢谢分享
3#
发表于 2011-4-28 09:00:50 | 只看该作者
谢谢分享
收下来
4#
发表于 2011-4-28 09:47:22 | 只看该作者
我正需要学习这方面知识,期望版主继续编写几个例子,感谢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-4-27 01:42 , Processed in 0.081386 second(s), 31 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表