GrantAccessToMultipleFiles 不适用于 Mac M1

如何解决GrantAccessToMultipleFiles 不适用于 Mac M1

我有几个在 Windows 上运行的 VBA 宏。我正在尝试将它们移植到 Mac m1,但在 Mac 上遇到了沙盒问题。每次宏尝试打开一个文件时,它都会触发一个访问权限对话框。 Microsoft 文档指出 GrantAccesstoMultipleFiles 是部分解决方案。

我编写了以下代码来扫描目录并枚举其中的所有文件以传递给 GrantAccesstoMultipleFiles。不幸的是,当我将 files 数组传递给例程时,什么也没有发生,除了它返回一个 True 指示访问被授予之外什么也没有发生。根本没有出现权限对话框。

稍后,当我的代码尝试打开枚举文件时,我收到一个访问权限请求对话框。我想可能有一个未记录的数组限制,所以只传递了几个文件但得到了相同的结果。

我做错了什么?

   Sub directoryGrant(dire)
   Dim files() As String
   Dim i,s,b As Boolean

   i = 0
   s = dir(dire)
   If s = "" Then End
   While s <> ""
     ReDim Preserve files(i)
     files(i) = s
     i = i + 1
     s = dir
   Wend

   b = GrantAccesstoMultipleFiles(files)
   If b = False Then i = i / 0
   End Sub 

正如我所说,上面的代码,如果它有效,那只是部分解决方案,因为稍后我的代码会下载客户端文件,直到它们到达时我才知道其名称。我需要能够在不触发权限对话框的情况下打开这些文件

有什么方法可以在 Mac 上禁用 Excel 的应用沙箱,以便我可以使用自己的计算机来完成我的工作?

*编辑更新。很早就,我尝试了“授予完整磁盘访问权限”来使 excel 无法正常工作。尝试 GrantAccesstoMultipleFiles 到同样不起作用的目录。那时,我写了上面的代码来看看这是否可行。那里也没有快乐。我终于尝试只授予对特定文件的访问权限,但该文件也不起作用。要么这是一个 M1 问题,我完全搞砸了,要么微软从来没有让它工作并发布。

解决方法

如果您只想在您的计算机上运行宏,您可以将 Excel 添加到具有“完整磁盘访问权限”的应用程序:

  • 开放系统偏好
  • 点击“安全和隐私”
  • 打开“隐私”标签
  • 向下滚动到“全盘访问”
  • 使用左下方的锁图标进行身份验证
  • 通过拖放或使用“+”按钮将 Excel 添加到列表中

您也可以尝试直接GrantAccessToMultipleFiles到目录(我不精通 VBA)。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?