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

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

Избранное

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


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

Вопрос №

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

Помощь

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


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

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

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

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

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

 
   
С Л С

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

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

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

Квинтана

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

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

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

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

 
  
АРХИВЫ

 
 

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

07-06-2006 02:13
Здравствуйте.
Извините за наглость, но я так и не смог найти, чтоб при нажатии на кнопку сохранялось, к примеру, 10 TstringGrid’ов в один Exel’евский файл. Если Вы знаете где это, дайте ссылку. Буду весьма признателен.

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

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

Ответы:


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

22-07-2006 11:10 | Комментарий к предыдущим ответам
Похоже, "дундук" взялся и »вопрос КС №41963«.

09-06-2006 12:39
>>>Надо постоянно переписивать Data для нового StringGrid'а?
Нет, нужно написать процедуру, параметрами которой будут StringGrid, Sheet и начальные координаты.
Если StringGrid-ов много, удобно организовать из них массив, тогда можно их выводить по циклу, а не писать 15 обращений к процедуре.

09-06-2006 06:13 | Сообщение от автора вопроса
to Shabal.
Sorry за надоедливость. А как мне в эту функцию запихнуть остальные TStringGrid'ы? Надо постоянно переписивать Data для нового StringGrid'а?
Например для 2-ух TStringGrid'ов это будет так:


.....
Data := VarArrayCreate([1, AGrid1.RowCount, 1, AGrid1.ColCount], varVariant);
  for i := 0 to AGrid1.ColCount - 1 do
    for j := 0 to AGrid1.RowCount - 1 do
      Data[j + 1, i + 1] := AGrid1.Cells[i, j];

Sheet.Range[RefToCell(1, 1), RefToCell(AGrid1.RowCount + 4 (Это смещение. Да?) ,
      AGrid1.ColCount)].Value := Data;

....



Мне кажется туповато, так как у меня их целая куча. Около 15!

08-06-2006 01:25 | Комментарий к предыдущим ответам
Все мы дуднуки, если на то пошло...

Для записи в один лист - то же самое что я писал, т.е. все в одном экземпляре XLApp и XLSheet, только теперь тебе нужно вычислять "смещение" для начальной строки при записи таблицы в лист. Т.е.
Смещение = Кол-во_строк_предыдущего_StringGrid + 4

На счет RefToCell - можно просто Sheet.Cells.Item[R + Смещение, C] или http://www.delphikingdom.com/asp/viewitem.asp?catalogid=1274#04

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

07-06-2006 11:46 | Сообщение от автора вопроса
А если мне надо не на разные листы, а на один лист все вычисления, скажем чтоб отступ от одного TStringGrida до другого был 4 ячейки. Как это сделать. Что надо изменить в этой функции, если можно бы с примерчиком для наглядности, а то я в этих RefToCell дундук!

07-06-2006 09:47 | Комментарий к предыдущим ответам
Может в ней что-то надо подправить?

1. Я бы подправил RefToCell, т.к. если колонок будет больше 26 у вас возникнут проблемы.
2. Потом использовал бы один экземпляр XLApp и книги для всех StringGrid
3. Добавил бы книгу с заданным кол-вом листов http://www.delphikingdom.com/asp/viewitem.asp?catalogid=1273#02
4. При переносе данных указывал бы номер листа, а не все время 1.

А так в общем все ничего так

07-06-2006 09:41 | Вопрос к автору: запрос дополнительной информации
А что конкретно не получается?

07-06-2006 09:34 | Сообщение от автора вопроса
1 умею. А вот 10 не знаю как.
Вот функция по сохранению:

Может в ней что-то надо подправить? А вот как я не знаю, не сталкивался никогда с такими вещами.


function RefToCell(ARow, ACol: Integer): string;
begin
  Result := Chr(Ord('A') + ACol - 1) + IntToStr(ARow);
end;

function SaveAsExcelFile(AGrid: TStringGrid; ASheetName, AFileName: string): Boolean;
const
  xlWBATWorksheet = -4167;
var
  Row, Col: Integer;
  GridPrevFile: string;
  XLApp, Sheet, Data: OLEVariant;
  i, j: Integer;
begin
  // Prepare Data
  Data := VarArrayCreate([1, AGrid.RowCount, 1, AGrid.ColCount], varVariant);
  for i := 0 to AGrid.ColCount - 1 do
    for j := 0 to AGrid.RowCount - 1 do
      Data[j + 1, i + 1] := AGrid.Cells[i, j];
  // Create Excel-OLE Object
  Result := False;
  XLApp := CreateOleObject('Excel.Application');
  try
    // Hide Excel
    XLApp.Visible := False;
    // Add new Workbook
    XLApp.Workbooks.Add(xlWBatWorkSheet);
    Sheet := XLApp.Workbooks[1].WorkSheets[1];
    Sheet.Name := ASheetName;
    // Fill up the sheet
    Sheet.Range[RefToCell(1, 1), RefToCell(AGrid.RowCount,
      AGrid.ColCount)].Value := Data;
    // Save Excel Worksheet
    try
      XLApp.Workbooks[1].SaveAs(AFileName);
      Result := True;
    except
      // Error ?
    end;
  finally
    // Quit Excel
    if not VarIsEmpty(XLApp) then
    begin
      XLApp.DisplayAlerts := False;
      XLApp.Quit;
      XLAPP := Unassigned;
      Sheet := Unassigned;
    end;
  end;
end;


07-06-2006 04:51 | Вопрос к автору: запрос дополнительной информации
1 stringGrid в один Exel’евский файл умеете?
Сделайте несколько раз, в чем проблема?

Добавьте свое 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» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

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