Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
6 / 6 / 4
Регистрация: 14.09.2010
Сообщений: 54

Считать из таблицы, отсортировать, залить ячейки 3х максимальных значений

24.04.2013, 11:25. Показов 2474. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет. Подскажите по VBA

Задание. Есть 15 магазинов и объемы их продаж (табл в Excel). Создайте проект, в котором ячейки с данными магазинов, занявших первое место по объему продаж, окрашивались бы в красный , второе – в синий, третье – в зеленый..

Зависла на этапе сортировки (не сортирует)
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
Private Sub bb3()
Dim a(1 To 15), b(1 To 15) As Integer
Dim i, Min, nmin As Integer
'считываем из таблицы
a(1) = Range("C10").Value
a(2) = Range("D10").Value
a(3) = Range("E10").Value
a(4) = Range("F10").Value
a(5) = Range("G10").Value
a(6) = Range("H10").Value
a(7) = Range("I10").Value
a(8) = Range("J10").Value
a(9) = Range("K10").Value
a(10) = Range("L10").Value
a(11) = Range("M10").Value
a(12) = Range("N10").Value
a(13) = Range("O10").Value
a(14) = Range("P10").Value
a(15) = Range("Q10").Value
'сортировка
For i = 1 To 14
If a(i) > a(i + 1) Then j = a(i) And a(i) = a(i + 1) And a(i + 1) = j Else a(i) = a(i) And a(i + 1) = a(i + 1)
Next i
'вывод в Immediate (для проверки, что отсортировал)
For i = 1 To 15
Debug.Print a(i)
Next i
End Sub
Помогите дописать сортировку (она не срабатывает почему то), хотя массив числовой получается. И как закрасить соответствующие ячейки? (Я только учусь)

Добавлено через 13 минут
Нашли все три максимума без сортировки (оказывается без нее тоже не сложно) так

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Max = 0
Debug.Print "Ìàêñèìóì"
For i = 1 To 15
If a(i) > Max Then Max = a(i)
Next i
Debug.Print Max
max1 = Max
 
Max = 0
For i = 1 To 15
If (a(i) > Max) And (a(i) < max1) Then Max = a(i)
Next i
Debug.Print Max
max2 = Max
 
Max = 0
For i = 1 To 15
If (a(i) > Max) And (a(i) < max2) Then Max = a(i)
Next i
Debug.Print Max
max3 = Max

Остался вопрос, как закрасить соответствующие ячейки?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.04.2013, 11:25
Ответы с готовыми решениями:

Выбрать 5 максимальных значений из таблицы
Мне необходимо выбрать 5 максимальных значений из таблицы.. Какое условие нужно написать для выборки именно 5 значений? И еще один...

Считать значение из ячейки таблицы Excel
Как например в int x записать значение из ячейки таблицы эксель файла... ? { //Создаём приложение. ...

Залить ячейки находящиеся на одной стороке с одинаковым текстом в другой ячейки находящейся в этой же строке
Здравствуйте. Вопрос от непонимающего. Как Залить ячейки находящиеся на одной стороке с одинаковым текстом в другой ячейки находящейся в...

3
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
24.04.2013, 11:33
Брр... Почему бы не поставить УФ с формулой НАИБОЛЬШИЙ()? Можно кодом
Или в цикле проверить по этой формуле?

Или нужен не результат, а процесс считывания, сортировки, определения 3х максимальных, закраска? И нельзя использовать формулы листа?
1
6 / 6 / 4
Регистрация: 14.09.2010
Сообщений: 54
24.04.2013, 11:44  [ТС]
Формулы листа использовать нельзя, к сожалению...

Разобралась как закрасить, но вот вопрос:
Можно ли проверить все значения в одном условии или надо для каждой ячейки отдельно расписывать?
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
'ñòîëáåö Ñ
If Range("C10").Value = max1 Then
 Range("C9:C10").Select
    With Selection.Interior
     .ColorIndex = 3
     .Pattern = xlSolid
    End With
End If
 
If Range("C10").Value = max2 Then
 Range("C9:C10").Select
    With Selection.Interior
     .ColorIndex = 33
     .Pattern = xlSolid
    End With
    End If
If Range("C10").Value = max3 Then
 Range("C9:C10").Select
    With Selection.Interior
     .ColorIndex = 43
     .Pattern = xlSolid
    End With
End If
 
'ñòîëáåö D
If Range("D10").Value = max1 Then
 Range("D9:D10").Select
    With Selection.Interior
     .ColorIndex = 3
     .Pattern = xlSolid
    End With
End If
If Range("D10").Value = max2 Then
 Range("D9:D10").Select
    With Selection.Interior
     .ColorIndex = 33
     .Pattern = xlSolid
    End With
    End If
If Range("D10").Value = max3 Then
 Range("D9:D10").Select
    With Selection.Interior
     .ColorIndex = 43
     .Pattern = xlSolid
    End With
End If
 
'ñòîëáåö E
If Range("E10").Value = max1 Then
 Range("E9:E10").Select
    With Selection.Interior
     .ColorIndex = 3
     .Pattern = xlSolid
    End With
End If
If Range("E10").Value = max2 Then
 Range("E9:E10").Select
    With Selection.Interior
     .ColorIndex = 33
     .Pattern = xlSolid
    End With
    End If
If Range("E10").Value = max3 Then
 Range("E9:E10").Select
    With Selection.Interior
     .ColorIndex = 43
     .Pattern = xlSolid
    End With
End If
Ну и т.д.

Попробовала ранг, например If Range("С10:Q10").Value = max2 Выдает Тип несовместим
0
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
24.04.2013, 12:11
Range("С10:Q10").Value - это массив! Его сравнить с одной переменной нельзя.

Закраску я бы делал так - имеем 3 переменных, в цикле идём по диапазону и каждое текущее значение с помощью select case сравниваем с этими переменными. Ну и красим.
Вопрос как быть, если получится два 1-х, два 2-х и т.д. (не вникал что там у Вас в коде с этим, без примера файла лениво...)

Добавлено через 16 минут
Судя по коду - будут 3 переменные с разными значениями. Далее проверяем диапазон и красим. В диапазоне таких значений может быть больше трёх - что делать?
Если использовать НАИБОЛЬШИЙ() - то тоже есть проблема: например с максимальным количеством 5 магазинов, и они все будут покрашены красным, все 5. Или в синий/зелёный, смотря как реализовывать покраску.
Ну по логике так и есть - всем пяти первое место, второго и третьего не присуждать
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.04.2013, 12:11
Помогаю со студенческими работами здесь

Как считать столбец значений из таблицы?
У меня такая проблема. Необходимо считать все значения из одного столбца таблицы для сравнения с другим числом. Можно как-то считать его из...

Перенос значений из ячейки в с список таблицы
На листе 1 таблица (график) в которой на каждый день есть 9 бригад которые выполняют по 8 заявок 4 в первой половине дня(с 9 -до 13)и 4 во...

Сравнение значений поля формы и ячейки таблицы сбоит
форма по нажатию кнопки сверяет поочередно значения полей формы и ячеек таблицы, в случае несовпадения, должны проводиться некоторые...

Автоматическое составление содержания ячейки из значений других ячеек таблицы
здравствуйте подскажите, пожалуйста, можно ли, не будучи программистом, сделать, чтобы в поле № таблицы базы Access был не порядковый...

Залить фоном ячейки условного форматирования
Здравствуйте, подскажите, пожалуйста макрос, который будет: 1. заливать фоном результаты в столбцах D и J (в таблицах &quot;Table1&quot;...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru