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

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

Избранное

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


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

Вопрос №

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

Помощь

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


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

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

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

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

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

 
   
С Л С

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

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

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

Квинтана

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

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

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

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

 
  
АРХИВЫ

 
 

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

09-05-2020 13:35
Знатоки, подскажите, по какой причине при передаче из Dephi в Excel некоторые символы (табуляция, переносы строк и др.) превращаются в квадратики?
Причём это наблюдается исключительно на Windows XP, на семёрке и десятке всё ОК.

Печать делаю так:

var
Res:TStringList;

begin

ExcelApp := CreateOleObject('Excel.Application');
ExcelApp.DisplayAlerts := false;
ExcelApp.Application.EnableEvents := false;
Workbook := ExcelApp.WorkBooks.Add(extractfiledir(application.ExeName) + '\ResultPrint.xlt'); //шаблон формата Excel 2003
Res:=TStringList.Create;
Res.Text:=connect.QueryExecute('SELECT PACK from ResultPack where RESULT_PACK_ID=' +ResultPackId ).DataSet.FieldByName('PACK').AsString; // запрос возвращает обычную строку, буз всяких квадратиков

...

WorkBook.WorkSheets[1].Cells[1, 1]:=Res.Text; //всё в одну ячейку, ячейка в шаблоне формата "общий"
Workbook.PrintOut;


Квадратики появляются независимо от принтера, если печатать в файл, они тоже есть. Если отображать созданную таблицу Excel - тоже.
Все кириллические шрифты в системе установлены. Ошибка проявляется на любом компьютере с ХР.

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

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

Ответы:


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

10-05-2020 01:09 | Вопрос к автору: запрос дополнительной информации
Попробуйте безо всяких запросов сделать такую штуку:

// копия из вашего кода
ExcelApp := CreateOleObject('Excel.Application');
ExcelApp.DisplayAlerts := false;
ExcelApp.Application.EnableEvents := false;
Workbook := ExcelApp.WorkBooks.Add(extractfiledir(application.ExeName) + '\ResultPrint.xlt'); //шаблон формата Excel 2003
// убран, или закомментирован блок получения информации из БД
// задание фиксированной строки
WorkBook.WorkSheets[1].Cells[1, 1]:= 'Hello'#13#10'world';
WorkBook.WorkSheets[1].Cells[1, 2]:= 'Hello'#10'world';
WorkBook.WorkSheets[1].Cells[1, 3]:= 'Hello'#13'world';
WorkBook.WorkSheets[1].Cells[1, 1]:= 'Hello'#10#13'world';


Посмотрите, во всех ли четырёх столбцах будет "квадратик" и если нет - то в каком именно его не будет. От этого будет зависеть решение проблемы (которое будет заключаться в обработке строки через StringReplace, а вот что на что менять надо будет - это и надо понять по результатам эксперимента). Если что, у меня OpenOffice, Excel под рукой нету (и ставить специально для эксперимента особенного желания нет).
Для чего этот эксперимент. Дело в том, что в системе Windows для переноса строки используется не один символ, а два: CR (carriage return, или возврат каретки) и LF (line feed, прогон строки). Формально, нужен только один LF, но исторически ставят именно два. Полагаю, что из базы возвращается последовательность CR+LF, а excel требуется только LF. Мой код позволяет проверить, так ли это.

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

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