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

Макросы вставки строки снизу в таблице Excel

23.12.2012, 00:31. Показов 41663. Ответов 85
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте!

Прошу вас помочь, сам я точно не справлюсь!!

В таблице, скажем, из 4-х столбцов (A,B,C,D) необходимо добавить строку снизу. При этом по столбцу A происходит автоматическая пере-нумерация. а последняя строка Итого: не удаляется. если можно

Прикрепил файл, содержащий таблицу. В силу своих возможностей в ней сделал макросы для Удаления строк. А со Вставками большой ступор. Смог только частично написать вставку снизу, но как сделать автоматическую нумерацию и формулу не знаю.

Заранее благодарен!
Вложения
Тип файла: xlsx Книга1.xlsx (13.4 Кб, 294 просмотров)
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.12.2012, 00:31
Ответы с готовыми решениями:

Макросы вставки строки сверху/снизу...
Здравствуйте! Прошу вас помочь, сам я точно не справлюсь!! В таблице, скажем, из 4-х столбцов...

vba Excel макросы на поиск четных и нечетных элементов в таблице
Здраствуйте,столкнулся с такой проблемой. Необходимо написать макрос в Excel , который по...

Вставка данных из Excel в ПолеТабличногоДокумента - некоторые строки после вставки объединяются
Нужно из екселя вставить данные в ПолеТабличногоДокумента, но проблема в том, что некоторые строки...

Вставки в Visual Studio - макросы и генерация ошибки компиляции
Доброе утро! Я должен написать программу на ассемблере в VS для работы с битовыми строками. В ней...

85
1 / 1 / 0
Регистрация: 13.02.2017
Сообщений: 7
13.02.2017, 20:45 61
Author24 — интернет-сервис помощи студентам
Visual Basic
1
2
3
4
5
6
7
Sub Insert_Rows2()
If Selection.Rows.Count > 1 Then Exit Sub
r_ = Selection.Row
    Rows(r_).Insert Shift:=xlDown
    Sheets("Ïîèñê").Rows("6:7").Copy Range("A" & r_)
        Application.CutCopyMode = False
End Sub
0
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
13.02.2017, 20:50 62
И что не так? Работает, ошибок нет...
1
1 / 1 / 0
Регистрация: 13.02.2017
Сообщений: 7
13.02.2017, 20:51 63
Visual Basic
1
2
3
4
5
6
7
Sub Insert_Rows2()
If Selection.Rows.Count > 1 Then Exit Sub
r_ = Selection.Row
Rows(r_).Insert Shift:=xlDown
Sheets("лист1").Rows("6:7").Copy Range("A" & r_)
Application.CutCopyMode = False
End Sub
0
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
13.02.2017, 20:52 64
Точно нужно сообщить? А то оно есть...
0
1 / 1 / 0
Регистрация: 13.02.2017
Сообщений: 7
13.02.2017, 20:56 65
приходиться каждый раз указывать ячейку куда вносить строки. Как можна сделать что бы после внесения данных автоматом активная ячейка будет первая ячейка внизу
Вложения
Тип файла: xlsx post++++9 - копия.xlsx (22.1 Кб, 23 просмотров)
0
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
13.02.2017, 21:03 66
Ну можно например писать в
Visual Basic
1
[A2].End(xlDown)(2)
или в A5, кто знает куда там Вы задумали чего вносить...
1
1 / 1 / 0
Регистрация: 13.02.2017
Сообщений: 7
13.02.2017, 21:26 67
не проходит
0
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
13.02.2017, 21:28 68
Поспорю - проходит!
1
1 / 1 / 0
Регистрация: 13.02.2017
Сообщений: 7
13.02.2017, 21:35 69
блин .... я чуть "туплю" , а можно попросить полным кодом скинуть?
0
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
13.02.2017, 21:39 70
Так это и есть полный код - встраивайте в свою задумку, я без понятия что там... Могу только гадать - может так?
Visual Basic
1
2
3
4
Sub Insert_Rows2()
    Sheets(1).Rows("6:7").Copy [A2].End(xlDown)(2)
    Application.CutCopyMode = False
End Sub
1
1 / 1 / 0
Регистрация: 13.02.2017
Сообщений: 7
13.02.2017, 21:49 71
Спасибо
1
0 / 0 / 0
Регистрация: 02.11.2017
Сообщений: 4
02.11.2017, 15:03 72
Добрый день!
Надеюсь не ошибся с темой!
Тема эта изъезженная до нельзя, но решения не смог найти.
На листе две таблицы и для каждой в отдельности необходимы кнопки добавить/удалить строки внизу таблицы.
Для одной таблицы скрипя у меня получилось сделать, для двух в отдельности ни как.
Важный момент, при добавлении строки она должна появляться внизу таблицы перед строкой "Итого", при этом должна брать формулы из строки стоящей над ней и в столбике продолжать порядковую нумерацию.

Помогите люди добрые!
Файлик прилагаю.
Вложения
Тип файла: rar Заявка___.rar (24.0 Кб, 26 просмотров)
0
1 / 1 / 0
Регистрация: 03.02.2017
Сообщений: 102
18.01.2018, 14:38 73
Здравствуйте Коллеги!

Доработал, просто потренироваться.

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Sub Строка()
'вставить строку
    Dim strInput As String, i As Long, iR, iBox, Message, Title, Default
        Message = "Укажите желаемое колличество строк!"
        Title = "Вставка сток в лист " & Chr(171) & ActiveSheet.Name & Chr(187)
        Default = "1"
N:      iBox = InputBox(Message, Title, Default)
    Select Case iBox
        Case "": Exit Sub
        Case Is > 0: On Error GoTo errN
            For i = 1 To iBox
                iR = Range("A2").End(xlDown).Row
                Rows(iR & ":" & iR).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
                Cells(iR, 1) = Cells(iR - 1, 1) + 1
            Next i
        Case Else
errN:       If MsgBox("Вы ввели не коректные данные!", vbRetryCancel + 64, Title) = vbRetry Then GoTo N
    End Select
End Sub
С уважением, Аватар-С
0
77 / 11 / 0
Регистрация: 28.03.2018
Сообщений: 828
30.01.2019, 12:47 74
Hugo121, не могу понять в чем дело. Ваша процедура, tt , из Книга1H.xls в файле работает, переношу в свою программу, и ошибка. показал на чистой книге. спасибо
Миниатюры
Макросы вставки строки снизу в таблице Excel  
0
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
30.01.2019, 12:54 75
Код здесь текстом опубликуйте, не перенабирать ведь... да и отсюда не видно где там l, а где 1
Не лучший выбор имени переменной в даннном случае. Это я писал?
1
77 / 11 / 0
Регистрация: 28.03.2018
Сообщений: 828
30.01.2019, 13:16 76
Hugo121, в 3 сообщении в этой теме.....а в 10 сообщении применили код на примере.в примере все работает. переношу в любую другую книгу, ошибка

Visual Basic
1
2
3
4
5
6
7
Sub tt()
    Dim L
    L = Range("A12").End(xlDown).Row
    Rows(L & ":" & L).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
    Cells(L, 1) = Cells(L - 1, 1) + 1
    Cells(L, 1).Borders.Weight = xlThin
End Sub
Вложения
Тип файла: zip 1.zip (11.6 Кб, 15 просмотров)
0
695 / 236 / 18
Регистрация: 17.01.2011
Сообщений: 583
Записей в блоге: 1
30.01.2019, 19:27 77
Попробуйте так:

Visual Basic
1
2
3
4
5
Dim L
    L = Range("A12").End(xlDown).Row + 1
    Rows(L & ":" & L).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
    Cells(L, 1) = Cells(L - 1, 1) + 1
    Cells(L, 1).Borders.Weight = xlThin
1
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
30.01.2019, 19:47 78
Лучший ответ Сообщение было отмечено dzug как решение

Решение

Вот эту часть строки не пробовали анализировать?
Visual Basic
1
Cells(L - 1, 1) + 1
Очевидно в файле, где работало было побольше строк с нумерацией, возможно это условие и оговаривалось...

Добавлено через 5 минут
Вернее так - код писался под таблицу типа
про 
1 
итого 
2
695 / 236 / 18
Регистрация: 17.01.2011
Сообщений: 583
Записей в блоге: 1
30.01.2019, 19:53 79
В Вашем файле из поста 10, выполнение строки

Visual Basic
1
l = Range("A12").End(xlDown).Row
выдаёт результат 14, а в файле mor_sergey, выдаёт 13, т.к. ниже этой строки отсутствует запись "ИТОГО" в объединённой ячейке..

А в сроке из файла топикстартера

Visual Basic
1
Cells(l, 1) = Cells(l - 1, 1) + 1
вызывает ошибку попытка сложить строку "про" с единичкой из 13 строки.


P.S.
Уважаемый Hugo, я сам у Вас многому научился и Ваши знания считаю на порядок выше моих..
1
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
30.01.2019, 19:58 80
Я естественно не помню на какой файл это писалось, но как вижу угадал, только что нашёл пост10
1
30.01.2019, 19:58
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
30.01.2019, 19:58
Помогаю со студенческими работами здесь

Поменять местами строки в таблице Excel
Здравствуйте! Подскажите, пожалуйста, как можно поменят местами строки?

Макросы на копирование данных из нескольких файлов excel в один файл excel
Здравствуйте! Помогите сделать два макроса в excel, которые будут копировать данные из множества...

Отступы сверху и снизу от картинки в таблице
Не могу найти решения данной проблеме) отступы сверху и снизу от картинки в <td>

Просмотр записей в таблице снизу вверх
Как сделать так, то есть прописать в SQL запрос, чтобы записи в таблицы показывались снизу вверх....


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

Или воспользуйтесь поиском по форуму:
80
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru