Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  10:56[Войти] | [Зарегистрироваться]
Ответ на вопрос № 76274

24-03-2010 01:43
Может кто подскажет, как посредством Delphi скопировать данные из одной книги (Excel) и вставить их в другую(Excel).

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

....
var
XL_1: Variant;
XL_2: Variant;
....
XL_2.Range['c6','c12'].Copy(EmptyParam);
XL_1.Range['d9','d15'].PasteSpecial(,,False,False);
....

выводит ошибку: "Метод PasteSpecial из класса Range завершен неверно"

Есть предположение, что необходимо активировать первую книгу для того, чтобы вставить данные из буфера обмена, но не получается (делал через XL_1.WorkBooks[1].Activate;).

Заранее благодарен.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

17-05-2012 06:16
Задача: скопировать из Word'a текст и таблицу через буфер в Excel. Как известно, Excel меняет формат данных при ставки, например, двадцатизначный счёт 40702810000400002588 преобразует в 4,07028E+19.
Решение: в Word выделяем текст и копируем его в буфер. С этим проблем нет, стандартный vba справляется.
в Excel вставляем следующим кодом:


...
var Excel, WorkBook, Sheet:Variant;
myRange: OleVariant;
begin
Excel := CreateOleObject('Excel.Application');
WorkBook:=Excel.WorkBooks.add;
Sheet := Workbook.Sheets.Item[1];
Excel.Application.Cells.Select;
Excel.Application.Selection.NumberFormat:='@';

Excel.Application.Selection.Range['A1',EmptyParam].PasteSpecial(xlPasteValues,,,);
Excel.visible:=true;
... //Дальше сохраняем, преобразуем и т.д.
end;



Спасибо огромное kilobait80, Работает только так: PasteSpecial(xlPasteValues,,,);

25-03-2010 04:29 | Комментарий к предыдущим ответам
>>>PasteSpecial(,,False,False);
и это вы называете с параметрами по умолчанию? Параметры что идут впереди для позднего связывания пропускать нельзя! Для раннего связывания указание двух первых параметров обязательно:

Sheet1.Range['A1:C10', EmptyParam].Copy(EmptyParam);
Sheet2.Range['B5', EmptyParam].PasteSpecial(xlPasteAll, xlPasteSpecialOperationNone, EmptyParam, EmptyParam);
XL.CutCopyMode[0] := 0;


Смотрите описание PasteSpecial и констант - может пригодиться:

function ExcelRange.PasteSpecial(Paste: XlPasteType; Operation: XlPasteSpecialOperation;
  SkipBlanks: OleVariant; Transpose: OleVariant): OleVariant;


Где:

type
  XlPasteType = TOleEnum;
const
  xlPasteAll = $FFFFEFF8;
  xlPasteAllExceptBorders = $00000007;
  xlPasteFormats = $FFFFEFE6;
  xlPasteFormulas = $FFFFEFE5;
  xlPasteComments = $FFFFEFD0;
  xlPasteValues = $FFFFEFBD;
  xlPasteColumnWidths = $00000008;
  xlPasteValidation = $00000006;
  xlPasteFormulasAndNumberFormats = $0000000B;
  xlPasteValuesAndNumberFormats = $0000000C;

type
  XlPasteSpecialOperation = TOleEnum;
const
  xlPasteSpecialOperationAdd = $00000002;
  xlPasteSpecialOperationDivide = $00000005;
  xlPasteSpecialOperationMultiply = $00000004;
  xlPasteSpecialOperationNone = $FFFFEFD2;
  xlPasteSpecialOperationSubtract = $00000003;


Ну и огласим весь список Microsoft Excel Constants

24-03-2010 23:51 | Сообщение от автора вопроса
Благодарю всех за ответы.

Но сработала вот такая конструкция .PasteSpecial(xlPasteValues,,,);

где
const
  xlPasteValues = -4163;

Причем метод PasteSpecial с параметрами по умолчанию не работает.


24-03-2010 03:21 | Комментарий к предыдущим ответам
>>>XL_1: Variant;
Для лучшего понимания что вы пишите и что "оно" делает, рекомендую использовать раннее связывание вместо позднего. Хотя при раннем связывании придется больше поработать руками, за то не будете себя чувствовать слепым котенком при написании кода.

24-03-2010 03:13
Если вы книги открыты в одном и тоже экземпляре Excel.exe, то очень просто:
Получаем ссылки на листы в книге_1 и книге_2, и копируем значения ячеек:

uses ExcelXP;
...
procedure TForm1.ButtonRangeCopyExampleClick(Sender: TObject);
var
  XL: TExcelApplication;
  Sheet1, Sheet2: ExcelWorksheet;
begin
  XL := TExcelApplication.Create(nil);
  try
    XL.ConnectKind := ckNewInstance;
    XL.AutoQuit := False;
    XL.Visible[0] := True;
    // открывем первую книгу и назначаем получаем ссылку на активеый лист
    Sheet1 := XL.Workbooks.Open('Книга1.xls',
      False, // UpdateLinks: OleVariant;
      False, // ReadOnly: OleVariant;
      EmptyParam, // Format: OleVariant;
      EmptyParam, // Password: OleVariant;
      EmptyParam, // WriteResPassword: OleVariant;
      EmptyParam, // IgnoreReadOnlyRecommended: OleVariant;
      EmptyParam, // Origin: OleVariant;
      EmptyParam, // Delimiter: OleVariant;
      EmptyParam, // Editable: OleVariant;
      EmptyParam, // Notify: OleVariant;
      EmptyParam, // Converter: OleVariant;
      False, // AddToMru: OleVariant;
      EmptyParam, // Local: OleVariant;
      EmptyParam, // CorruptLoad: OleVariant;
      0 // lcid: Integer
    ).ActiveSheet as ExcelWorksheet;
    // открывем вторую книгу и назначаем получаем ссылку на активеый лист
    // последняя открытая книга становится активной
    Sheet2 := XL.Workbooks.Open('Книга2.xls',
      False, // UpdateLinks: OleVariant;
      False, // ReadOnly: OleVariant;
      EmptyParam, // Format: OleVariant;
      EmptyParam, // Password: OleVariant;
      EmptyParam, // WriteResPassword: OleVariant;
      EmptyParam, // IgnoreReadOnlyRecommended: OleVariant;
      EmptyParam, // Origin: OleVariant;
      EmptyParam, // Delimiter: OleVariant;
      EmptyParam, // Editable: OleVariant;
      EmptyParam, // Notify: OleVariant;
      EmptyParam, // Converter: OleVariant;
      False, // AddToMru: OleVariant;
      EmptyParam, // Local: OleVariant;
      EmptyParam, // CorruptLoad: OleVariant;
      0 // lcid: Integer
    ).ActiveSheet as ExcelWorksheet;
    // Копируем данные из области A1:C10 листа Книги 1 в область B5 Книги 2
    // Нам не нужно делать активной книгу 1 для чтения/запси данных из Sheet1
    Sheet1.Range['A1:C10', EmptyParam].Copy(Sheet2.Range['B5', EmptyParam]);
  finally
    FreeAndNil(XL);
  end;
end;


Если книги открыты в разных Excel.exe, то передать значения можно только через копи-паст.
См. также
http://www.delphikingdom.com/asp/viewitem.asp?catalogid=1273
http://www.delphikingdom.com/asp/viewitem.asp?catalogid=1274

24-03-2010 02:39
Использовать буфер обмена для передачи данных внутри программы не очень хорошая идея. В вашем случае лучше использовать для этого вариантный массив:

var
XL_1: Variant;
XL_2: Variant;
Mas: Variant;
....
Mas := XL_2.Range['c6','c12'].Value[xlRangeValueDefault];
XL_1.Range['d9','d15'].Value[xlRangeValueDefault] := Mas;



Или обойтись даже без его объявления:

XL_1.Range['d9','d15'].Value[xlRangeValueDefault] :=
    XL_2.Range['c6','c12'].Value[xlRangeValueDefault];


Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
"Мы с тобой одной крови — ты и я!". Чьи это заветные слова?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования