Последние записи
- Преобразовать массив байт в вещественное число (single)
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
21st
Янв
Воспроизвести звук в Excel при появлении в ячейке заданного значения
Posted by obzor under VBA
В ячейке экселевского листа через DDE транслируются котировки. Дальше я перевожу их в проценты и мне нужно, чтобы, когда этот процент будет выше определенного значения, эксель инициировал бы звуковой сигнал. Скажем, если прибыль/убыток выше 5% от общей суммы счета, звучит сигнал. При этом желательно, чтобы этот звук воспроизводился бы виндой, то бишь без запуска медиа-плейера, и чтобы звуковой файл можно было бы менять (или повторять несколько раз, но это наверное сложнее, проще просто подставить отредактированный файл).
Можно с использованием системных звуков самой Windows
Sub sound()
iFileName = "C:\Windows\Media\chimes.wav"
iMacroFunction = "SOUND.PLAY(,""" & iFileName & """)"
ExecuteExcel4Macro iMacroFunction
End Sub
В коде модуля листа (пкм на ярлыке листа — исходный код) увидите вот такое
Sub Worksheet_SelectionChange(ByVal Target As Range)
If [a1] = 0.99 Then '99% - здесь проценты
Call Звук
End If
End Sub
Здесь и проценты прописаны и другие действия можно прописать
если число в ячейке больше, чем значение другой ячейки, которую я заполню руками |
примерно так
If [a1] > [a2] Then
Call Звук
End If
Чтобы, например, отслеживать события только в ячейках столбца А, а не на всем листе, можно написать так
Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim iTarget As Range
Set iTarget = Intersect(Me.Range("A1:A1000"), Target)
If Not iTarget Is Nothing Then
If [a1] > [a2] Then 'сравниваемые ячейки
Call Звук
End If
End If
End Sub
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)