Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/21: Рейтинг темы: голосов - 21, средняя оценка - 4.76
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26

Суммирование ячеек в столбце в зависимости от значений другого столбца

17.09.2015, 12:17. Показов 4551. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! В одном и столбцов имеется время, в другом сумма. Необходимо двойное условие, чтобы подсчитать сумму в необходимом интервале времени. Например, раньше 7:30:00 и позже 16:30:00. Ячейки, содержащие значение времени переведены в общий формат, поэтому отображаются как числа, таким образом я вычислил границы интервалов времени. Пока пытаюсь сделать подсчет суммы в ячейку B2 с одним временным условием. После выполнения скрипта в ячейке B2 оказывается значение 0.
Проверяемые ячейки находятся в столбце D, суммированные в столбце L.
Итак, что я имею :

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Sub FindAndSelect()
 
Dim sum As Double
sum = 0
Dim i As Integer
    
    With Worksheets("Лист 1")
        For i = 9 To i = 1000
        If Cells(i, 4) > 0.3125 Then
        sum = sum + Cells(i, 12)   
        End If
        Next i
       [B2] = sum 
                
    End With
End Sub
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.09.2015, 12:17
Ответы с готовыми решениями:

Суммирование столбцов в зависимости от значения другого столбца
Добрый день, имеется такая таблица: id user type vid sum 1 1 a 500 20 2 1 a 521 40 3 2 a 440 30 ...

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

Поиск значения ячеек одного столбца в столбце другого листа
Всем привет! Имеются два столбца на разных листах со значениями в ячейках. Нужно взять значение первой ячейки первого столбца, найти его в...

12
 Аватар для Апострофф
9908 / 3924 / 742
Регистрация: 11.10.2011
Сообщений: 5,904
17.09.2015, 12:25
Цитата Сообщение от banfollowesme Посмотреть сообщение
раньше 7:30:00
Цитата Сообщение от banfollowesme Посмотреть сообщение
Visual Basic
1
If Cells(i, 4) > 0.3125 Then 'а здесь позже?
Уточните, в чём собственно, проблема?
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26
17.09.2015, 13:11  [ТС]
Здравствуйте! Не раз уже переправлял условия и в целом синтаксис, поэтому получилась такая опечатка. В интервале больше 7:30 тоже получается 0. Мне кажется я использую не тот синтаксис или метод работы с ячейками.
0
 Аватар для Апострофф
9908 / 3924 / 742
Регистрация: 11.10.2011
Сообщений: 5,904
17.09.2015, 13:24
banfollowesme, приложите файл с данными, чтобы не играть в испорченный телефон.
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26
17.09.2015, 13:37  [ТС]
Файл в архиве, т.к. xslm сайт загружать не хочет
Вложения
Тип файла: 7z vb.7z (18.1 Кб, 7 просмотров)
0
 Аватар для Апострофф
9908 / 3924 / 742
Регистрация: 11.10.2011
Сообщений: 5,904
17.09.2015, 13:41
Сохраните в формате 97-2003 (XLS) или запакуйте ZIP`ом или RAR`ом (у меня нету 7z )
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26
17.09.2015, 13:45  [ТС]
Прошу прощения. Думал, что макросы удаляются при сохранении в обычном xls. Файл идентичен тому, в котором производится расчет, кроме количества записей.
Вложения
Тип файла: xls vb.xls (46.5 Кб, 20 просмотров)
0
 Аватар для pashulka
4139 / 2243 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
17.09.2015, 13:48
banfollowesme, Ваш первоначальный вариант, который позволит получить желаемый результат.

Visual Basic
1
2
3
4
5
6
7
8
9
10
Sub FindAndSum()
    Dim sum As Double, i As Integer
 
    With Worksheets("Лист 1")
        For i = 9 To 1000
            If .Cells(i, 4) < 0.3125 Then sum = sum + .Cells(i, 12)
        Next i
        .[C3] = sum
    End With
End Sub
Разумеется, здесь можно добавить и второе условие, причём, при желании можно вообще отказаться от цикла и использовать стандартные функции рабочего листа (в т.ч. и программно)
1
 Аватар для Апострофф
9908 / 3924 / 742
Регистрация: 11.10.2011
Сообщений: 5,904
17.09.2015, 13:51
Цитата Сообщение от banfollowesme Посмотреть сообщение
Visual Basic
1
For i = 9 To i = 1000
Извиняюсь, не разглядел сразу - так не пишется верхняя граница цикла, ничего удивительного что цикл от 9 до -1 не выполняется ни разу.
Исправьте
Visual Basic
1
For i = 9 To 1000
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26
17.09.2015, 14:51  [ТС]
Всем большое спасибо, работает! Скажите пожалуйста, как интерпретируется значение 5.78704E-05 : 0,0000578704?

Добавлено через 53 минуты
К сожалению, обнаружил, что для двух условий следующий код неприемлем:

Visual Basic
1
2
3
4
5
6
7
8
9
10
Sub FindAndSum()
    Dim sum As Double, i As Integer
 
    With Worksheets("Лист 1")
        For i = 9 To 1000
            If .Cells(i, 4) < 0.3125 Or .Cells(i, 4) > 0.6875 Then sum = sum + .Cells(i, 12)
        Next i
        .[C3] = sum
    End With
End Sub
Ошибка 13 Type mismatch. При этом с And вместо Or считает нормально(результат 0 по естественным причинам).

Следующий код тоже отказывается работать :
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Sub FindAndSum()
    Dim sum As Double, i As Integer
 
    With Worksheets("Лист 1")
        For i = 9 To 1000
            If .Cells(i, 4) < 0.3125 Then
            sum = sum + .Cells(i, 12)
            ElseIf .Cells(i, 4) > 0.6875 Then
            sum = sum + .Cells(i, 12)
            End If
        Next i
        .[C3] = sum
    End With
End Sub
// same error

Посмотрел довольно много примеров по использованию нескольких условий в У.О. if , но они почему-то не хотят работать.

Уважаемые форумчане, объясните пожалуйста, в чем состоят мои ошибки в использовании нескольких условий, и, чтобы мне не заваливать форум глупыми вопросами в будущем, скиньте надежный источник с гайдом по базовым вещам типа правильного обращения к ячейкам, использования условных операторов, циклов и проч. Все, что я нахожу самостоятельно не хочет работать при воспроизведении на моем компе.
0
 Аватар для Апострофф
9908 / 3924 / 742
Регистрация: 11.10.2011
Сообщений: 5,904
17.09.2015, 15:24
Лучший ответ Сообщение было отмечено banfollowesme как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Sub FindAndSum()
    Dim sum As Double, i As Integer
 
    With Worksheets("Лист 1")
        For i = 9 To 1000
          If IsNumeric(.Cells(i, 4)) Then
            If .Cells(i, 4) < 0.3125 Or .Cells(i, 4) > 0.6875 Then sum = sum + .Cells(i, 12)
          End If
        Next i
        .[C3] = sum
    End With
End Sub
1
 Аватар для pashulka
4139 / 2243 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
17.09.2015, 20:11
Если время это не результат вычислений формул, а константа, то можно также :

Visual Basic
1
2
3
4
5
6
7
8
Sub FindAndSum2()
    Dim cell As Range, sum As Double
 
    For Each cell In Лист1.[D:D].SpecialCells(xlConstants, xlNumbers)
        If cell < 0.3125 Or cell > 0.6875 Then sum = sum + cell(1, 9)
    Next
    Лист1.[C3] = sum
End Sub
P.S. Если в момент выполнения макроса - активным будет лист с именем "Лист 1", то здесь можно обойтись без кодового имени Лист1 (первый файл), а из всех остальных примеров можно убрать With ... End With и просто использовать Cells(row, column) и [C3]
2
0 / 0 / 0
Регистрация: 15.10.2015
Сообщений: 29
02.12.2015, 09:12
Добрый день уважаемые форумчане. есть код макроса. Но он копирует только одно значения принадлежащей фирмеHUFJAS из Книги211, в Книгу31. Что добавить для того чтобы в Книге211 HUFJAS считала сразу два значения и сумма копировалась в Книгу31.
Sub tt()
Dim c As Range

With Workbooks("Книга211.xlsm").Sheets(1)
For Each c In .UsedRange.Columns(1).Cells
If c.Offset(, 2) = "HUFWIEE" Then
With ThisWorkbook.Sheets(Format(c.Value, "yyyy.mm."))
.Cells(Day(c.Value) + 7, 2) = c.Offset(, 7)
.Cells(Day(c.Value) + 7, 7) = c.Offset(, 5)
End With
End If
Next
End With
End Sub
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.12.2015, 09:12
Помогаю со студенческими работами здесь

Поиск значения ячеек одного столбца в столбце другого листа
Всем привет! Имеются два столбца на разных листах со значениями в ячейках. Нужно взять значение первой ячейки первого столбца, найти его в...

Суммирование значений ячеек одного столбца dataGridView и вывести в textBox
Здравствуйте. Есть dataGridView, которая заполняется некоторыми значениями из БД. Надо найти сумму всех ячеек второго столбца. void Summ...

ComboBox в DataGridView. Изменение ячеек другого столбца в зависимости от выбора
Здравствуйте форумчане! У меня возник вопрос как организовать следующие действие На форме у меня есть datagridview в нем 5 колон...

Заполнение столбца в зависимости от значений ячеек в строке
Доброго времени суток, читающий. В VBA я достаточно слаб, чтобы решать настолько нетривиальную задачу. Суть в чем. Есть Словарь...

Заполнение одного столбца в зависимости от значений другого
У нас есть таблицы (с товарами) которые нужно обработать. Принцип следующий: 1) Если ячейка содержит нужную нам фразу, то другой...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru