Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> OA  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701835
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何用程序判断用户是否正在EXCEL某个单元格中进行编辑?

作者:cg1  摘自:access911.net  :cg1  更新日期:2012-11-30  浏览人次:

 

问题:

如何用程序判断用户是否正在EXCEL某个单元格中进行编辑?
当用户正在进行单元格编辑的时候,有些操作是不允许的,会出错。如果不想在每段程序中用错误陷阱来做,该如何预先测试出用户是否正在单元格中进行编辑?

 


回答:

EXCEL没有内建方法或者属性说明用户是否正在某个单元格中进行编辑。因此采用以下两个方法绕过去。
1、判断新建保存文档工具栏按钮是否可用。如果不可用一般就是用户正在编辑单元格
2、通过更改交互状态来判断。



'<CSCM>
'--------------------------------------------------------------------------------
' ProjectName   : assist911excel
' ComponentName : modPub
' ProcedureName : CellIsEditing
' VersionNumber : --
' Description   : Function
'                 判断 EXCEL 当前是否正在某个单元格中进行编辑
' Reference     : Microsoft Excel 11.0 Object Library
' Parameters    : editApp (Excel.Application)
' ReturnValue   : 如果用户正在编辑返回true。
' Demo          : CellIsEditing(myExcelApplication)
' CreateDate    : 2012-11-30 11:18:39
' ModifyDate    : 2012-11-30 11:18:39
' ExampleURL    : http://access911.net/?kbid;72FABF1E15DCE9F3
' Author        : cg1sh;cg1;access911
' WebURL        : http://access911.net
' EMail         : access911@gmail.com
' copyright     : 作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'--------------------------------------------------------------------------------
'</CSCM>

Function CellIsEditing(ByVal editApp As Excel.Application) As Boolean
On Error Resume Next
    If editApp.Interactive = False Then
        CellIsEditing = True
    Else
        editApp.Interactive = False
        editApp.Interactive = True
        If Err <> 0 Then
            '错误 :1004         对象 'Interactive' 的方法 '_Application' 失败
            Debug.Print Err.Number, Err.Description
            CellIsEditing = True
        Else
            CellIsEditing = False
        End If
    End If
End Function

 


本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利