Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
Word

Удаление пустых строк в таблице ворда

02.10.2022, 16:04. Показов 2666. Ответов 23

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

Есть на форуме похожие задачи, но под свою не получилось оптимизировать их.
Буду рад, если поможете!
Спасибо!
Вложения
Тип файла: docx Азово.docx (44.9 Кб, 32 просмотров)
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.10.2022, 16:04
Ответы с готовыми решениями:

Удаление пустых строк в таблице
Тема не нова, но почему-то не работает если в первой ячейке стоит знак абзаца. Прошу помощи, что делаю не так? Sub DeleteEmptyRows()...

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

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

23
665 / 334 / 135
Регистрация: 16.07.2020
Сообщений: 957
02.10.2022, 16:38
AndyChamin, Добрый вечер, прокрутите эту страницу вниз и просмотрите похожие темы.
0
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
02.10.2022, 16:55  [ТС]
Изучил все схожие темы на форуме. Я совсем далек от макросов, программирования и т.д.
У меня не получилось применить ничего из просмотренного(
0
665 / 334 / 135
Регистрация: 16.07.2020
Сообщений: 957
02.10.2022, 21:39
Цитата Сообщение от AndyChamin Посмотреть сообщение
У меня не получилось применить ничего из просмотренного
. Враньё, ничего ты не смотрел, за такое короткое время это невозможно сделать. Картина ясная - типичный лентяй и халявщик. Я пас - таким наглецам я не помогаю.
0
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
03.10.2022, 10:10  [ТС]
Очень странный вывод
Я проштудировал форум еще до того как создать данную тему.
Некоторые макросы, найденные на форуме, успешно применяю в работе, однако под данную задачу не могу их оптимизироваться.
Например с другой формой документа пользуюсь следующим кодом

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
    Dim oTable As Word.Table
    Dim lRowLength As Long
    Dim sRowText As String
    Dim i As Long
 
    For d = 1 To 400
         Set oTable = ActiveDocument.Tables(d)
         lRowLength = oTable.Columns.Count + 1
              Application.ScreenUpdating = False
               For i = oTable.Rows.Count To 1 Step -1
                   sRowText = oTable.Rows(i).Range.Text
                  sRowText = Replace(sRowText, Chr(13), "")
                  If Len(sRowText) = lRowLength Then
                  oTable.Rows(i).Delete
            End If
        Next i
        Application.ScreenUpdating = True
        Next d
        MsgBox "Код завершил работу", vbInformation
    
End Sub
Однако в данном документе он некорректно работает, удаляет только строки в одной таблице, в другой, где есть пустые ячейки, ничего не происходит.

В целом, для чего вешать на меня такие ярлыки я не совсем понимаю.
Если нет желания помочь мне в этом вопросе, я никого не заставляю, можно пройти мимо.
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
03.10.2022, 10:50
Цитата Сообщение от AndyChamin Посмотреть сообщение
днако в данном документе он некорректно работает, удаляет только строки в одной таблице, в другой, где есть пустые ячейки, ничего не происходит.
Так вроде там всё прозрачно - это код как раз для удаления пустых строк, но не строк, в которых среди непустых значений есть хотя бы одно пустое. И правится вроде элементарно - добавлением цикла перебора ячеек в строке:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Dim oTable As Word.Table
Dim lRowLength As Long
Dim sRowText As String
Dim i As Long, j As Long
 
Application.ScreenUpdating = False
For d = 1 To ActiveDocument.Tables.Count 'только по таблицам текущего документа
  Set oTable = ActiveDocument.Tables(d)
  lRowLength = oTable.Columns.Count' число колонок
  For i = oTable.Rows.Count To 1 Step -1 'перебор строк снизу вверх
    For j = 1 To lRowLength Step 1 перебор ячеек слева направо в выбранной строке
      sRowText = Trim(Replace(Replace(oTable.Cell(i, j).Range.Text, Chr(13), ""), Chr(7), "")) 'текст в ячейке без спецсимволов
      If Len(sRowText) = 0 Then 'если встретилась пустая ячейка
        oTable.Rows(i).Delete ' удалим строку
        Exit For 'прервём цикл по ячейкам строки
      End If
    Next j
  Next i
Next d
Application.ScreenUpdating = True
MsgBox "Код завершил работу", vbInformation
P.S. Данный код вроде должен работать только если в таблицах нет объединения ячеек. Если же есть объединённые ячейки - надо сначала определиться с логикой:
1. Нужно ли удалять все строки, через которые эта ячейка проходит, или только верхнюю?
2. Нужно ли удалять нижние строки, которые захватывает объединённая ячейка с непустым значением (поскольку в них её значение пустое, а не пусто только в верхней из объединённых), оставляя только верхнюю?
0
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
03.10.2022, 11:02  [ТС]
Цитата Сообщение от Punkt5 Посмотреть сообщение
Так вроде там всё прозрачно - это код как раз для удаления пустых строк, но не строк, в которых среди непустых значений есть хотя бы одно пустое. И правится вроде элементарно - добавлением цикла перебора ячеек в строке
Спасибо. Однако при запуске в документе выдает ошибку "5941, Запрашиваемый номер семейства не найден" с ссылкой на "sRowText = Trim(Replace(Replace(oTable.Cell(i, j).Range.Text, Chr(13), ""), Chr(7), "")) 'текст в ячейке без спецсимволов"

Может, конечно я что-то не то делаю
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
03.10.2022, 11:20
Цитата Сообщение от AndyChamin Посмотреть сообщение
Может, конечно я что-то не то делаю
Цитата Сообщение от AndyChamin Посмотреть сообщение
выдает ошибку "5941, Запрашиваемый номер семейства не найден"
Всё просто: Значит в этой таблице есть объединённые ячейки. И простой перебор строк, с последующим перебором ячеек строки к данной таблице неприменим. Нужен более изощрённый перебор собственно ячеек таблицы, с анализом .RowIndex и .ColumnIndex с удалением/оставлением в зависимости от выбранной логики (одной из вышеупомянутых или какой-то своей).
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,941
Записей в блоге: 4
03.10.2022, 11:25
AndyChamin,
Данный код вроде должен работать только если в таблицах нет объединения ячеек. Если же есть объединённые ячейки - надо сначала определиться с логикой:
у вас же в таблицах множество объединенных ячеек, по крайней мере в шапках таблиц
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
03.10.2022, 11:26
AndyChamin, Вдогон - хорошо бы ещё продумать, что делать со строками, в которых есть ячейки, объединённые по вертикали - искать ли для проверки верхнюю из объединённых ячеек (у неё .RowIndex будет другой) или пропускать, проверяя только те, что соответствуют данному .RowIndex?
Без выбора логики продолжать бессмысленно.
0
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
03.10.2022, 11:32  [ТС]
Цитата Сообщение от shanemac51 Посмотреть сообщение
у вас же в таблицах множество объединенных ячеек, по крайней мере в шапках таблиц
Цитата Сообщение от Punkt5 Посмотреть сообщение
Всё просто: Значит в этой таблице есть объединённые ячейки.
А можно при проверке ячеек их не учитывать?
Мне нужна корректировка необъединенных ячеек в строке 020 и 030
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
03.10.2022, 11:45
Цитата Сообщение от AndyChamin Посмотреть сообщение
Мне нужна корректировка необъединенных ячеек в строке 020 и 030
Ну, пропишите номера этих строк в цикле по строкам, если эти строки определимы заранее
Visual Basic
10
For i =  ... To ...
Или внутри цикла по строкам - проверяйте сначала нужную ячейку на значение sRowtext = "020" или "030" и только для нужных затем начинайте цикл перебора ячеек в строке по j.
0
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
03.10.2022, 12:08  [ТС]
Цитата Сообщение от Punkt5 Посмотреть сообщение
Ну, пропишите номера этих строк в цикле по строкам, если эти строки определимы заранее
020 и 030 это названия таблицы, это не сам номер строки) Немного лишней информации написал)

Добавлено через 15 минут
Цитата Сообщение от Punkt5 Посмотреть сообщение
Ну, пропишите номера этих строк в цикле по строкам, если эти строки определимы заранее
Если указываю номера строк, то выдает ошибку со ссылкой на строку
14. oTable.Rows(i).Delete
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
03.10.2022, 12:31
Цитата Сообщение от AndyChamin Посмотреть сообщение
Если указываю номера строк, то выдает ошибку со ссылкой на строку
14. oTable.Rows(i).Delete
Номера строк, надеюсь, в цикле от наибольшего к наименьшему? А то, при удалении строки выше, для удаления последующих надо пересчитывать как i, так и ограничение цикла сверху, с учётом количества удалённых строк - гемор тот ещё, да и вот такие ошибки вылезают.
0
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
03.10.2022, 18:08  [ТС]
Да, от большего к меньшему.
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
04.10.2022, 05:21
Лучший ответ Сообщение было отмечено AndyChamin как решение

Решение

AndyChamin, давайте попробуем такую логику:
1. Обрабатываем таблицу только если в в ней число ячеек = числу строк * число колонок. (то есть все таблицы, где есть объединённые ячейки - пропускаем)
2. В строке таблицы начинаем проверку ячеек на пустоту не с первой колонки, а СО ВТОРОЙ. (потому что, если в первой стоит автонумерация, то текста в данной ячейке нет - возвращает пустоту)
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Dim oTable As Word.Table
Dim i As Long, j As Long, d As Long, xStr As String
 
Application.ScreenUpdating = False
For d = 1 To ActiveDocument.Tables.Count 'только по таблицам текущего документа
  Set oTable = ActiveDocument.Tables(d)
  If (oTable.Columns.Count * oTable.Rows.Count) = oTable.Range.Cells.Count Then ' ячеек = колонок * строк
    For i = oTable.Rows.Count To 1 Step -1 'перебор строк снизу вверх
      For j = 2 To oTable.Columns.Count Step 1 'перебор ячеек со ВТОРОЙ в выбранной строке
        xStr = Trim(Replace(Replace(oTable.Cell(i, j).Range.Text, Chr(13), ""), Chr(7), ""))
        If Len(xStr) = 0 Then
          oTable.Rows(i).Delete ' если встретилась пустая ячейка - удалим строку
          Exit For 'прервём цикл по ячейкам строки
        End If
      Next j
    Next i
  End If
Next d
Application.ScreenUpdating = True
MsgBox "Код завершил работу", vbInformation
1
0 / 0 / 0
Регистрация: 18.12.2021
Сообщений: 10
04.10.2022, 18:52  [ТС]
Это магия какая-то, спасибо!
Вы сохранили десятки, а то и сотни часов моей жизни!
Все работает!
0
5 / 5 / 0
Регистрация: 25.07.2017
Сообщений: 53
06.10.2023, 07:45
Punkt5, подскажите, пожалуйста, можно ли как-то модифицировать этот код, чтобы удаление строк выполнялось только в случае, если абсолютно все ячейки в данной строке пустые (количество столбцов, и соответственно, количество ячеек в строке, разное: иногда в строке две ячейки, а иногда - 15)?
И ещё - в моих таблицах нет автонумерованных списков, поэтому в моём случае лычше начинать перебор ячеек не со второго столбца, а с первого.
Заранее спасибо!
0
малоболт
1328 / 510 / 213
Регистрация: 30.01.2020
Сообщений: 1,244
06.10.2023, 09:57
Цитата Сообщение от monetgen Посмотреть сообщение
можно ли как-то модифицировать этот код, чтобы удаление строк выполнялось только в случае, если абсолютно все ячейки в данной строке пустые (количество столбцов, и соответственно, количество ячеек в строке, разное
Можно.
0. Основной вопрос - будут ли в какой-нибудь таблице объединённые ячейки? Вот это:
Цитата Сообщение от monetgen Посмотреть сообщение
иногда в строке две ячейки, а иногда - 15)
внутри одной таблицы или в разных?

1. Что делать в тех случаях, когда объединённые ячейки есть?
1.1. пропускаем такую таблицу не разбираясь, как в коде выше?
1.2. Разбираемся только с теми строками, в которых объединённых ячеек нет?
1.3. Что-то другое?

Код для ответа 1.1 ниже:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Dim oTable As Word.Table
Dim i As Long, j As Long, d As Long, xStr As String, RowIsEmpty As Boolean
' ВСЕ таблицы, в которых есть объединённые ячейки - ПРОПУСКАЮТСЯ
Application.ScreenUpdating = False
For d = 1 To ActiveDocument.Tables.Count 'только по таблицам текущего документа
  Set oTable = ActiveDocument.Tables(d)
  If (oTable.Columns.Count * oTable.Rows.Count) = oTable.Range.Cells.Count Then ' ячеек = колонок * строк
    For i = oTable.Rows.Count To 1 Step -1 'перебор строк снизу вверх
      RowIsEmpty = True ' Изначально считаем строку пустой
      For j = 1 To oTable.Columns.Count Step 1 'перебор ячеек со ПЕРВОЙ в выбранной строке
        xStr = Trim(Replace(Replace(oTable.Cell(i, j).Range.Text, Chr(13), ""), Chr(7), ""))
        If Len(xStr) > 0 Then ' Если какая-то ячейка в строке НЕ ПУСТАЯ -
          RowIsEmpty = False ' Отметим себе, что строка НЕ ВСЯ пустая
          Exit For 'прервём цикл по ячейкам строки
        End If
      Next j
      If RowIsEmpty Then oTable.Rows(i).Delete ' если строка пустая ВСЯ
    Next i
  End If
Next d
Application.ScreenUpdating = True
MsgBox "Код завершил работу", vbInformation
1
5 / 5 / 0
Регистрация: 25.07.2017
Сообщений: 53
06.10.2023, 10:15
Punkt5, большое спасибо! Всё прекрасно работает для таблиц без объединённых ячеек!
А можно ли придумать какое-то решение для пункта 1.2?
Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.10.2023, 10:15
Помогаю со студенческими работами здесь

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

Удаление пустых строк
Этот код удаляет пустые строки, относительно столбца В On Error Resume Next ...

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

Удаление пустых строк в диапазоне
Ребят, у меня опять проблемы по невнимательности. Написал тут Private Sub CommandButton1_Click() Dim ra As Range, delra As Range ...

Удаление пустых строк Word
Добрый день. Столкнулся с проблемой при замене нескольких подряд идущих знаков абзаца(пустые строки в тексте) для их удаления...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
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
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru