Робин спрашивает, есть ли способ использовать возможности условного форматирования Excel для изменения шрифта, используемого в ячейке, или для изменения размера шрифта в ячейке. Короткий ответ — нет, это невозможно, по крайней мере, с условным форматированием. (Элементы управления, позволяющие указать имя и размер шрифта, отображаются серым цветом в диалоговом окне форматирования, используемом с условным форматированием.)

Однако вы можете использовать макрос для проверки содержимого ячейки и внесения изменений в ее внешний вид. Рассмотрим следующий макрос, который проверяет все ячейки, которые вы выбрали при запуске макроса. Если какая-либо из ячеек имеет длину более двух символов или значение более 10, то шрифт ячейки изменяется.

Sub DoReformat()

Dim rCell As Range

For Each rCell In Selection.Cells         If Len(rCell.Text) > 2 Or _           Val(rCell.Value) > 10 Then             rCell.Font.Name = "Arial"

rCell.Font.Size = 16         Else             rCell.Font.Name = "Times New Roman"

rCell.Font.Size = 12         End If     Next End Sub

Чтобы использовать макрос, просто выберите ячейки, которые вы хотите изменить, а затем запустите макрос. Если вы хотите, чтобы форматирование изменялось более автоматически, вы можете настроить макрос, чтобы увидеть, было ли изменение внесено в определенный диапазон ячеек:

Private Sub Worksheet_Calculate()

Dim rng As Range     Dim rCell As Range

Set rng = Range("A1:A10")



For Each rCell In rng         If Len(rCell.Text) > 2 Or _           Val(rCell.Value) > 10 Then             rCell.Font.Name = "Arial"

rCell.Font.Size = 16         Else             rCell.Font.Name = "Times New Roman"

rCell.Font.Size = 12         End If     Next End Sub

Этот макрос, добавленный к объекту рабочего листа, будет запускаться каждый раз при пересчете рабочего листа. Он проверяет диапазон A1: A10, применяя те же тесты, что и в предыдущем макросе. В результате форматирование ячеек постоянно проверяется и изменяется. Чтобы макрос проверял другой диапазон, просто измените адреса, присвоенные переменной rng в начале макроса.

Одним из недостатков этого макроса является то, что он может работать медленно, если у вас есть очень большой диапазон для проверки. Это будет происходить очень быстро, если вы проверяете A1: A10 (десять ячеек), но может идти намного медленнее, если вы постоянно проверяете B2: N465 (более 6000 ячеек). В этом случае вы можете разработать макрос так, чтобы он запускался всякий раз, когда рабочий лист изменяется, но предпринимает действия только в том случае, если изменение было внесено в ячейку в целевом диапазоне. Следующая версия также добавляется к объекту рабочего листа:

Private Sub Worksheet_Change(ByVal Target As Range)

Dim rCell As Range

If Union(Target, Range("A1:A10")).Address = _       Range("A1:A10").Address Then         Application.EnableEvents = False         For Each rCell In Target             If Len(rCell.Text) > 2 Or _               Val(rCell.Value) > 10 Then                 rCell.Font.Name = "Arial"

rCell.Font.Size = 16             Else                 rCell.Font.Name = "Times New Roman"

rCell.Font.Size = 12             End If         Next         Application.EnableEvents = True     End If End Sub

Макрос использует функцию Union, чтобы проверить, совпадают ли измененные ячейки (переданные обработчику событий в переменной Target) с диапазоном, который вы хотите проверить. Если да, то проверка выполняется в ячейках в целевом диапазоне.

При работе с макросами, влияющими на форматирование, следует помнить одну вещь: если условное форматирование применяется к ячейке, которая также проверяется макросом, форматирование в условном форматировании имеет приоритет над форматированием в макросе. Если ваш макрос изменяет имя и размер шрифта, это не вызывает большого беспокойства, поскольку условное форматирование не повлияет на эти атрибуты. Однако, если вы измените свой макрос, чтобы также изменить другой атрибут формата, например цвет ячейки, и этот атрибут также будет изменен условным форматом, то это не будет выглядеть так, как будто макрос что-то сделал, потому что Excel использует условное форматирование в предпочтении что делает макрос.

_Примечание: _

Если вы хотите узнать, как использовать макросы, описанные на этой странице (или на любой другой странице на сайтах ExcelTips), я подготовил специальную страницу, содержащую полезную информацию.

link: / excelribbon-ExcelTipsMacros [Щелкните здесь, чтобы открыть эту специальную страницу в новой вкладке браузера].

ExcelTips — ваш источник экономичного обучения Microsoft Excel.

Этот совет (2380) применим к Microsoft Excel 97, 2000, 2002 и 2003. Вы можете найти версию этого совета для ленточного интерфейса Excel (Excel 2007 и более поздних версий) здесь:

link: / excelribbon-Changing_Font_Face_and_Size_Conditional [Условное изменение шрифта и размера].