
    Новые сообщения [новые:0]
  
  Дайджест 
  
  Горячие темы
    Избранное [новые:0]
  
Форумы 
 
Пользователи 
Статистика 
Статистика нагрузки 
    Мод. лог 
  
  Поиск 
  | 
| 
 04.02.2014, 00:47 
 | 
|||
|---|---|---|---|
  
  | 
|||
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Привет всем! Ребята, возможно, вопрос этот уже обсуждался на форуме, однако, задам его по-новой. Если что, тыкните в ссылку:) Итак, ситуация часто распространенная. В процессе выполнения кода я вызываю некую функцию Windows, ну, например, "ping()"... Эта функция в конкретном примере пингует сервер, имя которого передается как аргумент. Все работает чудесно и хорошо, но.... На практике, как всегда, сервер не пингуется (ну, коннект хреновый, серв не отвечает), и я жду n-ное время, пока функция ping соизволит сообщить мне, что результат отрицательный. Все это время я смотрю в "зависшее" приложение, те код VBA. И скучаю. А ведь хочется на время этой вынужденной "заморозки", во время ожидания выполнения функции, видеть что-то типа прогрессбара или , на крайняк, анимированных часиков песочных. Вобщем, не тупо "спать" а обрабатывать нужный код, пока функция шарится по Интернету)). Или вот еще пример- считываю через Outlook письма с сервера. Пока идет коннект,основной код "висит", а хотелось бы хоть информировать юзера, что прога не зависла, а в процессе обработки. Когда я запускаю нужную функцию через SHELL, например, стартую командный файл, в котором делается часть работы,я, в ожидании окончания работы открытого приложения, могу хоть генерировать прогрессбар, а вот как быть при непосредственном использовании библиотечных функций Windows? Спасибо, я всё! ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 02:48 
 | 
|||
|---|---|---|---|
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Игорь_777основной код "висит", а хотелось бы... Тема не раз обсуждалась. По большому счету никак. Нужно выполнять задачи в разных потоках. А в VB6 ты второй поток с функцией потока в рамках единого приложения БУДЕМ СЧИТАТЬ не заюзаешь (API ф-ции кот. это делают в VB6 вылетают - проверено мной лично дважды). По идее можно извращаться с двумя exe. Например основной чего-то делает и шлет SendMessage-ы форме с прогрессбаром (которая отдельный exe-шник). ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 08:30 
 | 
|||
|---|---|---|---|
  
  | 
|||
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Игорь_777, DoEvents? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 10:15 
 | 
|||
|---|---|---|---|
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  DoEvents, Нет. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 13:59 
 | 
|||
|---|---|---|---|
  
  | 
|||
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Ребята, как я понимаю, DoEvents подходит в том случае, когда молотит мой основной код в каком-либо цикле, а чтоб не скучать, я DoEvents`ом обрабатываю фоновые события.  Как я вижу выход из ситуации: Придется использовать внешние вызовы функций, например, через BAT- файлы, запуская их через shell(). в таком случае просто юзать код ожидания завершения внешнего приложения, и в этом цикле ожидания и выводить прогрессбар. Хоть и кривоват этот метод, но он хоть работает. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 14:37 
 | 
|||
|---|---|---|---|
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Игорь_777 Хоть и кривоват этот метод, но он хоть работает.Нормально, самый правильный способ в ваших условиях. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 19:28 
 | 
|||
|---|---|---|---|
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Игорь_777внешние вызовы функций, например, через BAT- файлы, запуская их через shell()Тогда удобнее будет всё же через WSH, те же vbs/js. Даст больше возможностей для управления, да и визуальная составляющая намного легче реализуется. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
| 
 04.02.2014, 23:13 
 | 
|||
|---|---|---|---|
  
  | 
|||
Выполнение библиотечных функций Windows из VBA. Как избежать "заморозки" кода?  | 
|||
| 
 #18+ 
  
    
  Спасибо за добрые советы! ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 
  
  
   | 
  | 

start [/forum/topic.php?fid=60&tablet=1&tid=2156538]:  | 
    0ms | 
get settings:  | 
    9ms | 
get forum list:  | 
    12ms | 
check forum access:  | 
    3ms | 
check topic access:  | 
    3ms | 
track hit:  | 
    71ms | 
get topic data:  | 
    12ms | 
get forum data:  | 
    3ms | 
get page messages:  | 
    50ms | 
get tp. blocked users:  | 
    2ms | 
| others: | 12ms | 
| total: | 177ms | 

    | 0 / 0 | 

    Извините, этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
    
    
    «На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
    
    
    ... ля, ля, ля ...