Delphi excel удалить строку

Обновлено: 07.07.2024

Я хочу удалить строки из Excel с помощью программы Delphi7.
В этом случае создается исключение:

Что я делаю не так?

2 ответа

Как я могу изменить текст существующей формы excel из Delphi? Я могу создать новую фигуру и задать ее текст procedure TForm1.Button1Click(Sender: TObject); var excel, xlShape : variant; begin olecontainer1.CreateObject('Excel.Application',false); excel := olecontainer1.OleObject;.

Я хочу экспортировать данные в excel из Delphi без необходимости владеть копией excel, возможно ли это? N.B. CSV не годится.

Для меня работает следующее:

Обратите внимание, что я использую раннюю привязку, которая значительно облегчает жизнь. Просто включите устройство Excel2000, и этот код будет работать для вас.

Использование ранней привязки позволит вам перехватывать подобные ошибки во время компиляции, а не затруднять диагностику ошибок во время выполнения.

Если вы хотите продолжить с поздней привязкой, то, как утверждает Sertac, это работает:

Не забудьте сначала создать рабочую книгу!

Rows - это свойство рабочего листа . Так что это должно сработать:

Похожие вопросы:

Мы пытаемся передать строку из нативной программы Delphi в программу Delphi Prism DLL. У нас нет проблем с передачей целых чисел, но строки не совпадают в DLL. Мы видели фрагмент кода Роберта Лава в.

Я провожу некоторые тесты с использованием модулей python-excel. Кажется, я не могу найти способ удалить строку в листе excel с помощью этих модулей, и интернет не предложил решения. Есть ли способ.

Как я могу изменить текст существующей формы excel из Delphi? Я могу создать новую фигуру и задать ее текст procedure TForm1.Button1Click(Sender: TObject); var excel, xlShape : variant; begin.

Я хочу экспортировать данные в excel из Delphi без необходимости владеть копией excel, возможно ли это? N.B. CSV не годится.

Я пытаюсь вызвать Delphi DLL из Excel и вернуть столбец значений вариантных данных. У меня есть dll, возвращающий одну короткую строку, и она появляется в ячейке ok. Теперь я пытаюсь вернуть столбец.

У меня есть этот фрагмент кода, который находит строку excel элемента из списка и удаляет элементы из списка. То, что я хочу. это значит также удалить строку Excel. Код здесь Private Sub.

Я не могу удалить строку существующего листа excel с помощью JXL. Есть ли другой способ удалить строку из существующей книги?

Как я могу удалить строку из листа excel на основе идентификатора продукта, указанного в textbox1. Используя этот product_id, он должен удалить всю строку из excel листа & и отобразить.

У меня есть Excel от клиента (который сгенерировал его из функции print-to-Excel), странно то, что Excel содержит временную строку '06:15:00' в ячейку с общим форматом. Я должен создать identitcal.

Александр Шабля
дата публикации 26-05-2006 08:58

  • Как записать значения сразу в несколько ячеек?
  • Как определить область выделенных ячеек и ее границы?
  • Как записывать значения в ячейку (Value, Value2, Text, Formula)?
  • Что работает быстрее, запись в Range или Cells?
  • Что такое UsedRange? Как найти последнюю используемую ячейку? Что такое SpecialCells? Что такое CurrentRegion?
  • Как получить адрес ячейки?
  • Нужно ли выделять ячейку/область для того чтобы вносить в нее данные?
  • В чем отличие Range.Activate от Range.Select?
  • Как установить свойству ячейки NumberFormat "общий" формат, текстовый формат, формат даты, числа, валюты?
  • Передаю в ячейку 385.00, а показывает 385. Почему?
  • При записи в ячейку чисел как текста, целые числа автоматический преобразуются в численный формат, а вещественные нет. Вследствие чего возникает ошибка "число сохранено как текст".
  • Делаю экспорт в Excel, допустим, текст "000069987", а он выводит в ячейку 69987, т.е. удаляет лидирующие нули. Как мне сделать, чтобы в ячейку выводилось 000069987?
  • Как очистить область ячеек? Как определить что ячейка Excel пустая?
  • Как задать имя области ячеек? Как обратиться к ячейке по имени? Как определить, что такое имя существует на листе? Как задать имя области ячеек?
  • Как объеденить ячейки? Как узнать, что ячейка входит в объединенную область и определить границы этой области?
  • Как записывать данные из вариантного массива в Excel?
  • Как прочесть данные из области ячеек в массив?
  • Почему при выгрузке данных в Excel не могу записать строк больше 65536?
  • Как писать в ячейки нескольких листов сразу?
  • Как изменить цвет фона и шрифта ячейки?
  • Как изменить атрибуты шрифта части текста в ячейке (цвет, размер, имя)?
  • Как узнать позицию курсора в редактируемой по F2 ячейке или в строке формул и дописать в нее текст?
  • Как изменить выравнивание/угол наклона текста, отступы в ячейке?
  • Как задать границы для области ячеек (Borders)?
  • Как скопировать форматы и формулы из строки в нижележащую область (AutoFill)?
  • Как скопировать область ячеек с сохранением всех форматов? Как скопировать только значения ячейки?
  • Как скопировать область, чтоб сохранились размеры строк/столбцов?
  • Как сделать автоперенос строк в ячейке?
  • Как вставить несколько строк/столбцов? Как удалить несколько строк/столбцов? Как прятать/показывать строки и столбцы? Как программно изменить высоту строки или ширину столбца?
  • Как подогнать высоту или ширину ячеек для отображения всего текста?
  • Как сделать автоподбор высоты строк для объединенных ячеек?
  • Как программно "заморозить" строки/столбцы?
  • Как добавить примечание к ячейке? Как удалить примечание? Как изменить атрибуты шрифта примечания?
  • Как добавить URL? Как сделать гиперссылку для рисунка?
  • Как отсортировать область ячеек?
  • Как сделать поиск значений в области ячеек или по всему листу?
  • Как, имея ссылку на ячейку, узнать имя листа, которому она принадлежит? Узнать имя книги?

Константа lcid в примерах определена как

Cells, Range, Rows, Columns

Объект Cells предназначен для доступа к ячейкам в стиле R1C1 к одной ячейке. Range — в стиле A1 к области (коллекции) ячеек. Удобство объекта Range в том, что можно, при использовании оператор with, обращаться к нескольким свойствам и методам. Объект Rows возвращает коллекцию строк и Columns — коллекцию столбцов объекта Range (вместо этих свойств можно использовать свойства EntireRow и EntireColumn).

Как записать значения сразу в несколько ячеек?

Для записи в несколько (область) ячеек используется объект Range (ExcelRange). Пример как можно получить объект Range для области ячеек.

Заметьте, что при обращении к свойству Range и Cells объекта Range, адресация будет уже работать относительно области, указанной в объекте Range. Например, нижеприведенный код будет указывать не на ячейку "A1", как сразу можно подумать, а на "C2":

А вот такой код вернет ячейку с адресом "D3":

Как определить область выделенных ячеек и ее границы?

Чтоб получить область (или области) выделенных ячеек нужно получить объект Range из свойства Selection объекта Excel.Application и обратиться к свойству Range.Areas.

Как записывать значения в ячейку (Value, Value2, Text, Formula)?

Для записи локализованных ("русских") форматов данных и формул используются свойства с окончанием Local, например FormulaLocal.

Если вы попробуете записать макрос в Excel, то увидите, что запись значений ведется в свойство FormulaR1C1. С тем же успехом можно писать и в свойство Formula.

Внимание! При записи в свойство Formula, если это не формула, следите, чтобы текст не начинался с символов "=", "+", "-", "*", "/". Или просто к тексту прибавляйте в начало знак апострофа (код символа 39):

Что работает быстрее, запись в Range или Cells?

Для перевода из координат R1C1 в A1 удобно пользоваться "самодельными" функциями, например:

Что такое UsedRange? Как найти последнюю используемую ячейку? Что такое SpecialCells? Что такое CurrentRegion?

UsedRange — прямоугольная область, включающая все заполненные ячейки и незаполненные, в промежутках между заполненными ячейками, на листе. Координаты области не обязательно начинаются в ячейке A1. Также для определения координат различных ячеек можно использовать объект SpecialCells, например, с параметром xlCellTypeLastCell для нахождения последней (крайней справа снизу) используемой ячейки. CurrentRegion возвращает область вокруг ячейки, выделенную пустыми (незаполненными) ячейками. End — находит последнюю ячейку в строке или столбце перед первой попавшейся пустой ячейкой, или первую заполненную, если вызывать метод End для пустой ячейки.

Как получить адрес ячейки?

Нужно ли выделять ячейку/область для того чтобы вносить в нее данные?

Не нужно. Достаточно указать адрес области ячеек в объекте Range для выбранного объекта Worksheet (и/или Workbook). Любой Select или Activate только замедлит работу вашей программы. Кроме того, метод Select возможно вызвать только на активном листе активной книги! Не используйте Select и Activate без необходимости.

В чем отличие Range.Activate от Range.Select?

И метод Activate и Select делают одно и то же — выделяют (активируют) ячейку. Разница лишь в том, что метод Activate позволяет выбрать только одну ячейку на листе или сделать активной любую ячейку в области, выделенной методом Select. Метод Select позволяет выделять одну и более областей ячеек.

Как установить свойству ячейки NumberFormat "общий" формат, текстовый формат, формат даты, числа, валюты?

Для правильной работы NumberFormat с английскими форматами не забудьте подключить модуль TrDispCall

Передаю в ячейку 385.00, а показывает 385. Почему?

Потому что в ячейке установлен "общий" формат (general), который отсекает не значащие цифры. В данном примере всегда будут указываться 2 цифры после запятой:

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

Лучше числа не записывать в ячейку как текст и не надеяться, что Excel всегда сможет "на лету" преобразовать текст верно. Вы никогда не можете быть уверенными, какие локальные установки формата чисел будут установлены на компьютере пользователя. Всегда перед записью переводите записываемые числа из текста в число (Float или Integer) в своей программе.

Делаю экспорт в Excel, допустим, текст "000069987", а он выводит в ячейку 69987, т.е. удаляет лидирующие нули. Как мне сделать, чтобы в ячейку выводилось 000069987?

При записи текста, содержащего одни цифры, Excel пытается его преобразовать в число. Чтобы избажать такой "помощи" со стороны Excel'я перед записью в ячейку установите в свойтво NumberFormat текстовый формат или добавьте перед текстом символ апострофа "'" (код символа 39).

Как очистить область ячеек? Как определить что ячейка Excel пустая?

Чтобы радикально очистить ячейки (данные, форматы, примечания и т.д.) можно вызвать метод Clear.

Как задать имя области ячеек? Как обратиться к ячейке по имени? Как определить, что такое имя существует на листе? Как задать имя области ячеек?

Если вы зададите области имя уже существующее в листе, то старое имя будет утеряно, т.е. получится перезапись имени. Присваивать имена области ячеек можно и не активному листу. Задавать адрес ячейки можно и как текст (не обязательно ссылку на объект Range), а также можно в стиле R1C1, указав адрес области ячеек в параметре RefersToR1C1.

Как объеденить ячейки? Как узнать, что ячейка входит в объединенную область и определить границы этой области?

Смотрите дальше как сделать автоподбор высоты строк для объединенных ячеек.

Как записывать данные из вариантного массива в Excel?

Запись данных из вариантного массива (VarArray) очень хорошо расписана в статьях "По волнам интеграции… III" и "Зарисовка на тему экспорта в Excel". Для разнообразия, приведу еще раз этот вариант быстрого экспорта в Excel.

Внимание! Если вы пытаетесь записать в область одну строку, то МАССИВ все равно ДОЛЖЕН БЫТЬ ДВУМЕРНЫМ! Т.е. varData := VarArrayCreate([1, 1, 1, ColumnCount], varVariant); При записи массива вы должны указать в адресе области ячеек Range ВСЮ область для заполнения.

Как прочесть данные из области ячеек в массив?

Точно также как и при экспорте, только самому создавать массив не нужно — Excel все сделает за вас. В принципе, после получения данных в массив, Excel уже не нужен, и от него можно отсоединиться.

Почему при выгрузке данных в Excel не могу записать строк больше 65536?

Потому что это максимально возможное количество строк объекта Worksheet. Если вы записываете больше строк, чем 65536, то помещайте их на следующий лист книги — благо, что количество листов ограничено только оперативной памятью комьютера.

Как писать в ячейки нескольких листов сразу?

Чтобы занести данные в несколько листов сразу, вы можете объединить листы методом Worksheets.Select и воспользоваться методом FillAcrossSheets

Как изменить цвет фона и шрифта ячейки?

Смотрите свойства Font и Interior объекта Range

Как изменить атрибуты шрифта части текста в ячейке (цвет, размер, имя)?

Чтобы изменить часть текста ячейки можно воспользоваться свойством Characters объекта Range.

Как узнать позицию курсора в редактируемой по F2 ячейке или в строке формул и дописать в нее текст?

Никак! При входе в режим редактирования ячейки объект Excel.Application становится полностью недоступен через OLE.

Как изменить выравнивание/угол наклона текста, отступы в ячейке?

Смотрите свойства HorizontalAlignment, VerticalAlignment, AddIndent и Orientation объекта Range

Как задать границы для области ячеек (Borders)?

Смотрите свойство Borders объекта Range.

Как скопировать форматы и формулы из строки в нижележащую область (AutoFill)?

Это как раз самый удобный метод копирования форматов и формул для расширения области данных при использовании шаблонов. Подразумевается, что между НАЧАЛО/КОНЕЦ находится подготовленные ячейки шаблона (форматирование, именованная область DataRange для данных).

Как скопировать область ячеек с сохранением всех форматов? Как скопировать только значения ячейки?

Метод Copy позволяет не только копировать содержимое области ячеек в буфер обмена (при пустом параметре), но и задать конкретный адрес ячеек для копирования. Если вы хотите вставить из буфера только некоторые параметры скопированной в БО ячейки, то для вставки используйте метод PasteSpecial, указав необходимый XlPasteType (первый аргумент).

Как скопировать область, чтоб сохранились размеры строк/столбцов?

К сожалению, при копировании не сохраняются размеры строк и столбцов. Для сохранения размеров строк и столбцов можно использовать несколько способов:

Как сделать автоперенос строк в ячейке?

Чтобы сделать перенос слов в ячейке установите свойство WrapText объекта Range.

Как вставить несколько строк/столбцов? Как удалить несколько строк/столбцов? Как прятать/показывать строки и столбцы? Как программно изменить высоту строки или ширину столбца?

Как подогнать высоту или ширину ячеек для отображения всего текста?

Для отображения всего текста в ячейке или области ячеек используйте метод AutoFit объекта Range.

Как сделать автоподбор высоты строк для объединенных ячеек?

Как известно, метод AutoFit для подбора высоты объединенных ячеек не срабатывает. Для этого был придуман простой метод (взят отсюда и просто адаптирован под Delphi). Работает для объеденных ячеек в одной строке. Просто укажите одну из объединенных ячеек области (свойство WrapText должно быть включено).

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

Как программно "заморозить" строки/столбцы?

Как добавить примечание к ячейке? Как удалить примечание? Как изменить атрибуты шрифта примечания?

Комментарий — это своеобразный объект Shape, привязанный к определенному объекту Range.

Как добавить URL? Как сделать гиперссылку для рисунка?

Как отсортировать область ячеек?

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

Как сделать поиск значений в области ячеек или по всему листу?

Как, имея ссылку на ячейку, узнать имя листа, которому она принадлежит? Узнать имя книги?

Получить ссылку на объект Worksheet, содержащий данную ячейку можно из свойства Parent.

Для работы с Excel в Delphi, первым делом нужно в Uses указать модуль ComObj.

Как запустить Excel и открыть новый документ в Delphi

XL : = CreateOLEObject ( 'Excel.Application' ) ; // Создание OLE объекта

Как обратиться к отдельным ячейкам листа Excel в Delphi

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 1 , 1 ] . Value : = '30' ;

//Результатом является присвоение ячейке [1,1] первого листа значения 30. Также к ячейке

Как добавить формулу в ячейку листа Excel в Delphi

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 3 , 3 ] . Value : = '=SUM(B1:B2)' ;

Форматирование текста в ячейках Excel, производится с помощью свойств Font и Interior объекта Cell:

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 1 , 1 ] . Interior . Color : = clYellow ;

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 1 , 1 ] . Font . Color : = clRed ;

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 1 , 1 ] . Font . Name : = 'Courier' ;

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 1 , 1 ] . Font . Size : = 16 ;

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Cells [ 1 , 1 ] . Font . Bold : = True ;

Работа с прямоугольными областями ячеек, с помощью объекта Range:

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Range [ 'A1:C5' ] . Value : = 'Blue text' ;

XL . WorkBooks [ 1 ] . WorkSheets [ 1 ] . Range [ 'A1:C5' ] . Font . Color : = clBlue ;

//В результате в области A1:C5 все ячейки заполняются текстом 'Blue text'.

Как выделить группу (область) ячеек Excel в Delphi

Как установить объединение ячеек, перенос по словам, и горизонтальное или вертикальное выравнивание Excel в Delphi

Как задать границы ячеек Excel в Delphi

Как выровнять столбцы Excel по ширине, в зависимости от содержания

Как удалить столбец Excel в Delphi

Как задать формат ячеек Excel в Delphi

XL . columns [ 1 ] . NumberFormat : = '@' ; // текстовый формат

XL . columns [ 1 ] . NumberFormat : = 'm/d/yyyy' ; // формат дата

XL . columns [ 1 ] . NumberFormat = '0.00%' // формат процентный

Поиск по сайту

Okolokompa в Яндекс Дзен

Delphi Tokyo, Excel 2016. Используя программу Delphi, я контролирую Excel. Я пытаюсь удалить все строки в одном листе EXCEPT строк, которые имеют определенное значение в определенном столбце. Например, у меня есть список предприятий, где столбец 3 является ГОРОДОМ бизнеса. Мне нужно удалить все строки EXCEPT, где находится City ("Чикаго", "Денвер", "Колумбус"). Я построил и просмотрел макрос Excel, чтобы увидеть, как это делает Excel. В частности, он включает AutoFilter, выбирает все значения EXCEPT этих городов, а затем удаляет. У меня есть вопрос. как узнать, что значения находятся в этом столбце.

Вот код макроса VBA.

Мне нужно создать массив ВСЕХ городов, ЗА ИСКЛЮЧЕНИЕМ тех, которые я хочу удалить. AutoFilter знает, что все уникальные значения. Как я могу прочитать Autofilter (или список уникальных значений) за пределами простое повторение всех строк?

AutoFilter знает, что все уникальные значения. Как читать Autofilter

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

Возможно, самым близким вы могли бы определить, какие строки в отфильтрованном диапазоне отображаются на экране, а затем удалять те, которые нет. Этот код показывает, как определить, какие строки скрыты. Но для меня это, скорее всего, "вокруг дома", и в любом случае это не то, что вы специально задали.

Таким образом, вам придется каким-то образом перебрать диапазон самостоятельно.

Мне нужно создать массив ВСЕХ городов, ЗА ИСКЛЮЧЕНИЕМ тех, которые я хочу удалить.

На самом деле это гораздо проще сделать в коде Delphi, если вы игнорируете Excel AutoFilter, потому что это почти тривиально, чтобы найти уникальные значения ячеек в диапазоне Excel с помощью кода Delphi.

Ниже я покажу, как сделать в этом ответе эквивалент Delphi формулы Coderre. До вас, что вы предпочитаете.

Запустите новый проект Delphi VCL и опустите на него TCheckListBox. Затем выполните компиляцию и выполните приведенный ниже код. Код заполняет диапазон Excel такими значениями, как A, B & C, а затем извлекает уникальные значения и заполняет их ChecklistBox. После этого вы можете использовать состояния отдельных флажков для обработки диапазона Excel любым удобным вам способом.

Кстати, если вы посмотрите на один из блоков импорта для объектов автоматизации Excel, например Excel2000.Pas, вы увидите, что в нем определен интерфейс для IAutoFilter, поэтому вы могли бы, возможно, получить доступ к этому из кода Delphi, если хотите.

Также, кстати, если бы я делал это сам, я бы, вероятно, сделал манипуляции с данными в SQL, обратившись к электронной таблице, используя объект ADO, такой как TAdoQuery, потому что такие операции, как "удалить все строки, где какое-то значение столбца отсутствует в списке значений", кричит для такого рода лечения.

Читайте также: