Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 28.09.2007
Сообщений: 285

Как получить программный доступ ко всем зависимым ячейкам на листе Excel

27.10.2007, 02:18. Показов 1235. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как при обновлении всех зависимых ячеек в Excel все их переформатировать? Видимо, на событии Worksheet1_Calculate, но как получить программный доступ ко всем зависимым ячейкам на листе Excel?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.10.2007, 02:18
Ответы с готовыми решениями:

Как получить доступ к ячейкам Excel через C#?
Делаю один проэкт на C# в конце различных вычислений куча результатов, есть идея вывести их всех в Excel, чтобы было красиво, так вот как...

Как получить доступ к ячейкам DBGrid?
Здравствуйте! Мне нужна помощь. Тут вот какое дело, у меня есть база данных в Access, к которой я подключился из Delphi, и отобразил...

Как получить доступ к ячейкам табличной части?
Всем привет. Есть табличная часть с реквизитом "Сумма". Как получить доступ к ячейке текущей строки реквизита "Сумма"?.

5
VladK
27.10.2007, 08:39
...как получить программный доступ ко всем зависимым ячейкам на листе Excel?
Visual Basic
1
2
ActiveSheet.Cells.SpecialCells(xlCellTypeFormulas).Activate
ActiveSheet.Cells.SpecialCells(xlCellTypeFormulas).NumberFormat = '0.00_);[Red](0.00)'
1 / 1 / 0
Регистрация: 28.09.2007
Сообщений: 285
27.10.2007, 20:32  [ТС]
VladK, спасибо! Действительно, то, что просил!
Но как оказалось, просил не совсем то , что хотел, Я рассчитывал на событии Calculate обойти все ячейки с формулами и занести в них .Value значение , оформатированное по своему формату, которого нет во встроенных в Excel (Например, надо числа представлять с разделителем целой и дробной в виде знака =
(1223.75 как 1223=75) ), А потом восстановить старую формулу в ячейке, вроде следующего:
Visual Basic
1
2
3
4
5
 For Each FrmlCell In ActiveSheet.Cells.SpecialCells(xlCellTypeFormulas)
  a = FrmlCell.Formula
  FrmlCell = Мое представление
  FrmlCell.Formula = a
 Next FrmlCell
Но не тут-то было . При пересчете происходит перескакивание по событиям On Change, Calculate с зацикливанием. Видимо надо как- то по другому форматировать ячейки своим форматом, но как ?....
0
VladK
28.10.2007, 06:40
...Видимо надо как- то по другому форматировать ячейки своим форматом, но как ?....

EXCEL допускает любые форматы, т.к. в нем есть формат CUSTOM. В нем Вы указываете Ваше представление для Value. Рассматриваемый случай (замена '.' на '=') проблематичен, т.к. требует вместо смены формата смену региональных установок. Открываете Control Panel, потом - Regional Setting, потом - Number и заменяете '.' на '='.

1 / 1 / 0
Регистрация: 28.09.2007
Сообщений: 285
28.10.2007, 21:43  [ТС]
Что это за формат Custom, я смог обнаружить только свойство <Range>.NumberFormat. Если можно, подскажите как заменить форматирование Excel на свою оригинальную функцию форматирования.
0
VladK
29.10.2007, 06:04
Да, пожалуйста.
1. В меню кликаете Tools/Macro/Record New Macro. Затем кликаете кнопку ОК на появившейся форме. Это вы начали записывать макро для последующего возможного использования в коде.
2. Кликаете правой клавишей на любую ячейку в листе, содержащюю ваше типичное число, которое нужно отформатировать.
3. В выпрыгнувшем меню выбираете Format Cells...
4. В появившейся форме кликаете на закладку Number.
5. В лист боксе Category выбираете Custom.
6. В списке готовых форматов находите формат, наиболее близко похожий на желаемый и меняете его по своему вкусу в текстовом окне Type:
7. Внутри рамки Sample смотрите что получилось и редактируете пока не удовлетворитесь полученным форматированием вашего числа.
8. Все закрываете и в Tools/Macro/Stop Recording останавливаете макро.
9. В кодовом окне будет сидеть ваша форматирующая строка, которую и надо будеть применить примерно так как я показал в своем первом ответе.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.10.2007, 06:04
Помогаю со студенческими работами здесь

Как получить доступ к ячейкам DBGrid после SQL-запроса ADOQuery
Здравствуйте! Я на C++ Builder-е программирую давно но с Базами данных столкнулся впервые, т.к. решаю моделирую математические модели. ...

Как получить/записать данные в документ Excel с разноской по ячейкам?
Кто знает как получить/записать данные в документ Excel с разноской по ячейкам. спсибо.

Объект IE.Application, как получить программный доступ к вкладкам
Программно создал объект &quot;InternetExplorer.Application&quot; Подразумевается, что пользователь в нем откроет несколько вкладок. Которые мне...

Доступ к объединенным ячейкам в Excel
Имеется куча файлов Excel (анкет) требуется все их обработать и перегнать нужные данные в базу MS Access. Все это несложно. Пока возник...

Доступ к выделенным ячейкам Excel
Добрый день. Прошу помогите. Знаю способ чтения данных из выделенных ячеек Excel: ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru