【access小品】中心开花--自定义函数编制讲座二-煮江品茶
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-教程


【access小品】中心开花--自定义函数编制讲座二

发表时间:2011/4/28 6:37:41 评论(3) 浏览(6459)  评论 | 加入收藏 | 复制
   
摘 要:自定义函数编制讲座
正 文:

  编写自定义函数时,一般需要找到所需功能的核心算法,这个算法可先从一个特例开始进行编写。中心开花,逐步抽象,递次外延,直到获得满足功能需求的完整代码。下面以版友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

 点击下载此附件

 

 上一课   下一课


Access软件网交流QQ群(群号:198465573)
 
 相关文章
【access小品】逐步扩展--自定义函数编制讲座一  【煮江品茶  2011/4/26】
【access小品】情侣函数--自定义函数编制讲座三  【煮江品茶  2011/5/21】
【access小品】姊妹函数--自定义函数编制讲座四  【煮江品茶  2011/5/31】
【access小品】一打两就--自定义函数编制讲座五  【煮江品茶  2011/6/15】
【access小品】裸奔--自定义函数编制讲座六  【煮江品茶  2011/6/20】
常见问答
技术分类
相关资源
文章搜索
关于作者

煮江品茶

文章分类

文章存档

友情链接