Access交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • 获取系统闲置了多久(用户多..
  • 人事系统中计算员工工龄
  • Access实现连续及不连..
  • Access VBA 四舍..
  • Access VBA字符串..
  • 产生一个1-N 的不重复随..

最新文章

  • 获取系统闲置了多久(用户多..
  • Access VBA字符串..
  • Access实现连续及不连..
  • Access VBA 四舍..
  • Access程序设计——递..
  • Access在指定位置插入..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 模块/函数/VBA/API/系统 > 经典算法
经典算法

Access或VB VBA判断数组是否为空的几种方法


方法一:Error方法


就是采用通用的错误捕获功能

On Error Goto 行号       '遇到错误,转到行号处处理

On Error Resume Next '忽略错误,继续执行

On Error Goto 0           '强制取消错误捕获功能

Function IsNotEmpty(ByVal sArray As Variant) As Boolean '判断数组是否为空

        Dim i     As Long

        IsNotEmpty = True

        On Error GoTo lerr:

        i = UBound(b)

        Exit Function

lerr:

        IsNotEmpty = False

End Function


方法二:CopyMemory方法


VB的数组都是安全数组,通过访问一个结构来确定 数组内容保存位置,上标下标和维数

安全数组结构的地址可以用

Private Declare Function VarPtrArray Lib "msvbvm60.dll" Alias "VarPtr" (ByRef Ptr() As Any) As Long

Private Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" _

             (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)

安全数组的头两位就保存着维数信息

Option Explicit

Private Declare Function VarPtrArray Lib "msvbvm60.dll" Alias "VarPtr" (ByRef Ptr() As Any) As Long

Private Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)

Private Sub Form_Load()

    Dim MyArr() As Long

    Dim pMyarr As Long

    Dim nDims As Integer

    '从数据指针得到SafeArray结构的指针

    CopyMemory pMyarr, ByVal VarPtrArray(MyArr), 4

    If pMyarr = 0 Then

        MsgBox "这个数组是空数组"

        '再从这个指针所指地址的头两个字节取出cDims

        CopyMemory nDims, ByVal pMyarr, 2

        MsgBox "这个数组有" & nDims & "维"

    End If

End Sub


方法三:使用api函数safearraygetdim()的返回值,返回值值<=0,说明数组元素个数为0或者数组还没有初始化.


SafeArrayGetDim用来判断一个数组的维数,该函数在MSDN中定义为:

UINT SafeArrayGetDim(

  SAFEARRAY FAR* psa

转换维VB中的语法格式为:

Public Declare Function SafeArrayGetDim Lib "oleaut32.dll" (ByRef saArray() As Any) As Long

如果数组已经初始化,则返回非0,否则返回0。

'API判断数组为空或没有初始化

Sub diag()

Dim msg As String

Dim arr1() As String, arr2() As String, arr3() As Date, arr4() As Date, arr5() As Range, arr6() As Range

msg = "arr1 " & IIf(SafeArrayGetDim(arr1) > 0, "数组不为空!", "数组为空!")

arr2 = Split("一、二、三、四、五、六", "、")

msg = msg & vbCrLf & "arr2 " & IIf(SafeArrayGetDim(arr2) > 0, "数组不为空!", "数组为空!")

msg = msg & vbCrLf & "arr3 " & IIf(SafeArrayGetDim(arr3) > 0, "数组不为空!", "数组为空!")

ReDim arr4(1 To 100)

msg = msg & vbCrLf & "arr4 " & IIf(SafeArrayGetDim(arr4) > 0, "数组不为空!", "数组为空!")

ReDim arr6(1 To 256, 1 To 65536)

msg = msg & vbCrLf & "arr5 " & IIf(SafeArrayGetDim(arr5) > 0, "数组不为空!", "数组为空!")

msg = msg & vbCrLf & "arr6 " & IIf(SafeArrayGetDim(arr6) > 0, "数组不为空!", "数组为空!")

MsgBox msg

End Sub


方法四:使用cstr(Join(list[, delimiter]))函数的返回值是否不等于""


将delimiter参数设置为""

例如:if (cstr(join(arr,""))) = "" then msgbox "arr 数组为空或者尚未初始化"




标签:  vba,数组,空值,函数,Access vba 数组 空值 函数 Access
发布人:  
分享到:
点击次数:  更新时间:2016-04-26 15:13:58  【打印此页】  【关闭】
上一条:让Access的自动编号字段从1开始编号  下一条:常见的筛选代码错误



相关文章

  • • 获取系统闲置了多久(用户多久没有操作)的源码
  • • Access VBA字符串转换函数
  • • Access实现连续及不连续数据排名
  • • Access VBA 四舍六入逢五奇进偶不进函数
  • • Access程序设计——递归(重复)
  • • Access在指定位置插入记录
  • • 搜索指定文件夹中的文件
  • • 人事系统中计算员工工龄

热门文章

  • [2016-04-26] Access或VB VBA判断数组是否为空的几种方法access数据库
  • [2017-04-21] 搜索指定文件夹中的文件access数据库
  • [2016-07-14] 产生一个1-N 的不重复随机数access数据库
  • [2017-09-07] Access VBA字符串转换函数access数据库
  • [2017-09-01] Access VBA 四舍六入逢五奇进偶不进函数access数据库
  • [2017-12-26] 获取系统闲置了多久(用户多久没有操作)的源码access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn