vba excel как вызвать SHCreateDirectoryExA в office 2013

windows excel VBA

Declare Function SHCreateDirectoryEx Lib "shell32" Alias "SHCreateDirectoryExA" _
(ByVal hwnd As Long, ByVal pszPath As String, _
ByVal PSA As Any) As Long

Очень нужный кусок для выполнения одного очень нужного макроса в Excel. В 2010 работал без проблем. Поставил 2013 и теперь не работает, что делать? Поставить обратно 2010 нельзя. Еще такой вопрос, можно ли унифицировать вызов этой библиотеки, чтобы макрос работал и в 2010, и в 2013 (думаю, можно использовать индийский select case с какой-нибудь функцией, которая возвращающее версию WinApi)?
П.С:В vba умею делать только самые примитивные вещи, так что поподробнее, если можно.
Ответы:
Попробуйте добавить в самом начале глобальное объявление через Public, помниться у меня с какой-то WinAPI был такой затык. По теории это возможно решит и проблему универсальности.


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.