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, 陳格 保留所有權利