URL: https://www.opennet.ru/cgi-bin/openforum/vsluhboard.cgi
Форум: vsluhforumID15
Нить номер: 3793
[ Назад ]

Исходное сообщение
"рендер html в jpg  pdf  ps  doc  xls"

Отправлено Магистр , 20-Мрт-12 16:45 
Дано:
    есть аддонс к FireFox в котором генерятся из шаблонов различные бухгалтерские документы (накладные, акты, счета...). Выходной формат html. Возникла необходимость получить документ в другом формате. Вручную можно сохранить документ в PS  | PDF а из них и в картинку можно... Также OpenOffice может html перевести в doc. Но!... это все вручную. Требуется автоматизировать процесс. Вот какие идеи посетили:
    FireFox передает драйверу какой-то файл в съедобном формате. Если этот файл перехватить, то можно в консоли с ним сделать все что угодно. Вопрос в том как его перехватить, да и в каком виде/формате он передается драйверу? По поводу конвертации в doc/xls ответ найден -- aptitude install unoconv... а вот с другими пока затык. Перехватить бы ТО что драйверу передается -- и вопрос почти решен
    Может у кого-нить есть другой ход мыслей?...

Содержание

Сообщения в этом обсуждении
"рендер html в jpg  pdf  ps  doc  xls"
Отправлено ACCA , 20-Мрт-12 23:19 
Посмотри Selenium. Работает нормально, хотя я так и не осилил HtmlUnitDriver, пришлось рулить Firefox.

"рендер html в jpg  pdf  ps  doc  xls"
Отправлено Магистр , 21-Мрт-12 08:27 
... может можно FF заставить через JavaScript отрендерить html в pdf например. Когда нажимаешь Файл-Печать вызывается ведь какая-то функция... наверняка ее можно самому вызвать

"рендер html в jpg  pdf  ps  doc  xls"
Отправлено dgv , 21-Мрт-12 13:45 

Я использую libreoffice (раньше OO)

/usr/lib/libreoffice/program/soffice.bin --invisible Macro:///"Standard.Module1.SaveAsXLS(/[путь к файлу]/$fn)"

Он хорошо конвертирует в любой формат
на васике пишется простенький скрипт (SaveAsXLS или любой другой формат доступный в soffice
)
Примерный текст скрипта:
====================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
<script:module xmlns:script="http://openoffice.org/2000/script" script:name="Module1" script:language="StarBasic">REM  *****  BASIC  *****

' Сохранить документ в формате Microsoft Word.

Sub SaveAsXLS( cFile )
   ' практически совпадает с SaveAsPDF
   cURL = ConvertToURL( cFile )
   oDoc = StarDesktop.loadComponentFromURL(cURL,"_blank",0,Array(MakePropertyValue( "Hidden", True ),))


   cFile = Left( cFile, Len( cFile ) - 4 ) + ".xls"
   cURL = ConvertToURL( cFile )
  
   oDoc.storeToURL( cURL, Array(_
            MakePropertyValue( "FilterName", "MS Excel 97" ),)
   oDoc.close( True )

End Sub

Sub SaveAsODS( cFile )
   cURL = ConvertToURL( cFile )
   oDoc = StarDesktop.loadComponentFromURL(cURL,"_blank",0,Array(MakePropertyValue( "Hidden", True ),))
   cFile = Left( cFile, Len( cFile ) - 4 ) + ".ods"
   cURL = ConvertToURL( cFile )
   oDoc.storeToURL( cURL, Array(_
            MakePropertyValue( "FilterName", "" ),)
   oDoc.close( True )
End Sub

Function MakePropertyValue(Optional cName As String, Optional uValue) As com.sun.star.beans.PropertyValue
   Dim oPropertyValue As New com.sun.star.beans.PropertyValue
   If Not IsMissing( cName ) Then
      oPropertyValue.Name = cName
   EndIf
   If Not IsMissing( uValue ) Then
      oPropertyValue.Value = uValue
   EndIf
   MakePropertyValue() = oPropertyValue
End Function
Sub Main
End Sub
Sub Macro1
End Sub
</script:module>
=============================
Конечно, можно намного короче, но я взял его где-то готовый, подправил и все уже несколько лет работает в автоматическом режиме..