Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Excel VBA (часть 2)

Модерирует : ShIvADeSt

ShIvADeSt (11-01-2010 10:17): http://forum.ru-board.com/topic.cgi?forum=33&topic=10903  Версия для печати • ПодписатьсяДобавить в закладки
На первую страницук этому сообщениюк последнему сообщению

   

AndVGri

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору


Код:
 
Public Sub SplitListBy150()
    Dim i As Long, pos As Long, vId As Long, vSum As Long
    Dim pSource As Worksheet, pDest As Worksheet
     
    Set pSource = ActiveSheet
    Set pDest = Worksheets.Add
    vId = 1&: vSum = 0&: pos = 1&
     
    For i = 1& To 8&
        If (vSum + pSource.Cells(i, 2&).Value) > 150& Then
            pDest.Cells(pos, 1&).Value = pSource.Cells(i, 1&).Value
            pDest.Cells(pos, 2&).Value = 150& - vSum
            pDest.Cells(pos, 3&).Value = vId
            vSum = pSource.Cells(i, 2&).Value - 150& + vSum
             
            vId = vId + 1&: pos = pos + 2&
            pDest.Cells(pos, 2&).Value = vSum
        Else
            pDest.Cells(pos, 2&).Value = pSource.Cells(i, 2&).Value
            vSum = vSum + pSource.Cells(i, 2&).Value
        End If
        pDest.Cells(pos, 1&).Value = pSource.Cells(i, 1&).Value
        pDest.Cells(pos, 3&).Value = vId
        pos = pos + 1&
    Next i
End Sub
 


Всего записей: 750 | Зарегистр. 14-12-2005 | Отправлено: 18:34 03-05-2007
   

На первую страницук этому сообщениюк последнему сообщению

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Excel VBA (часть 2)
ShIvADeSt (11-01-2010 10:17): http://forum.ru-board.com/topic.cgi?forum=33&topic=10903


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru