| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 822 人关注过本帖
标题:VB 检测系统office
只看楼主 加入收藏
sdgzs
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2012-11-23
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:5 
VB 检测系统office
VB 导出excel 时,系统没有安装office 程序会出现假死,怎样判断系统安装office ?
搜索更多相关主题的帖子: VB 检测 office 系统 安装 
2023-06-14 14:43
厨师王德榜
Rank: 18Rank: 18Rank: 18Rank: 18Rank: 18
等 级:贵宾
威 望:199
帖 子:989
专家分:4966
注 册:2013-2-16
收藏
得分:20 
oXls = CreateObject("Excel.Application")  ' 看看oXls能否返回OLE对象.
2023-06-14 15:29
sdgzs
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2012-11-23
收藏
得分:0 
oXls = CreateObject("Excel.Application") 这句在没有安装office,而装有WPS的机器上,也能返回
2023-06-15 06:14
厨师王德榜
Rank: 18Rank: 18Rank: 18Rank: 18Rank: 18
等 级:贵宾
威 望:199
帖 子:989
专家分:4966
注 册:2013-2-16
收藏
得分:0 
是的,WPS也能返回,能返回就行.
不必在意OLE对象是WPS还是EXCEL.
只要能返回,就能做接下来的事.
2023-06-15 08:50
sdgzs
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2012-11-23
收藏
得分:0 
问题是 WPS 能返回,但系统不能导出数据,还造成系统假死。
2023-06-16 05:17
约定的童话
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:56
帖 子:246
专家分:1442
注 册:2021-8-1
收藏
得分:0 
通过检查注册表判断
Public Function isOfficeInstalled() As Boolean
    Dim oRegKey As Object
    Dim strPath As String
   
    On Error Resume Next
   
    ' 检查 Office 2016 的注册表项
    strPath = "HKLM\Software\Microsoft\Office\ClickToRun\ProductReleaseIds"
    Set oRegKey = GetObject("winmgmts:{impersonationLevel=impersonate}!\\.\root\default:StdRegProv")
   
    If oRegKey.EnumKey(HKEY_LOCAL_MACHINE, strPath, SubKeys) =  Then
        For Each subkey In SubKeys
            If subkey = "Office16" Then
                ' Office 2016 已安装
                isOfficeInstalled = True
                Exit Function
            End If
        Next subkey
    End If
   
    ' Office 2016 未安装
    isOfficeInstalled = False
   
End Function
2023-06-18 12:52
快速回复:VB 检测系统office
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025579 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved