【access小品】中心开花--自定义函数编制讲座二
时 间:2011-04-28 06:37:41
作 者:煮江品茶 ID:10802 城市:武汉
摘 要:自定义函数编制讲座
正 文:
编写自定义函数时,一般需要找到所需功能的核心算法,这个算法可先从一个特例开始进行编写。中心开花,逐步抽象,递次外延,直到获得满足功能需求的完整代码。下面以版友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群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 【Access高效办公】按日期...(06.12)
- 合并列数据到一个文本框的示例;...(05.06)
- 通过命令按钮让Access列表...(04.24)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)

学习心得
最新文章
- Access快速开发平台--Acc...(06.16)
- 【Access高效办公】按日期区间...(06.12)
- Access快速开发平台--生成复...(06.07)
- 仓库管理实战课程(25)-导航菜单...(06.06)
- 仓库管理实战课程(24)-库存月结...(06.05)
- 分享一个简单的X氏家谱小示例(06.04)
- 仓库管理实战课程(23)-先入先出(06.02)
- 仓库管理实战课程(22)-代理商库...(05.30)
- 仓库管理实战课程(21)-安全库存...(05.28)
- Access快速开发平台--如何添...(05.26)