Дано:
есть аддонс к FireFox в котором генерятся из шаблонов различные бухгалтерские документы (накладные, акты, счета...). Выходной формат html. Возникла необходимость получить документ в другом формате. Вручную можно сохранить документ в PS | PDF а из них и в картинку можно... Также OpenOffice может html перевести в doc. Но!... это все вручную. Требуется автоматизировать процесс. Вот какие идеи посетили:
FireFox передает драйверу какой-то файл в съедобном формате. Если этот файл перехватить, то можно в консоли с ним сделать все что угодно. Вопрос в том как его перехватить, да и в каком виде/формате он передается драйверу? По поводу конвертации в doc/xls ответ найден -- aptitude install unoconv... а вот с другими пока затык. Перехватить бы ТО что драйверу передается -- и вопрос почти решен
Может у кого-нить есть другой ход мыслей?...
Посмотри Selenium. Работает нормально, хотя я так и не осилил HtmlUnitDriver, пришлось рулить Firefox.
... может можно FF заставить через JavaScript отрендерить html в pdf например. Когда нажимаешь Файл-Печать вызывается ведь какая-то функция... наверняка ее можно самому вызвать
Я использую 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 SubFunction 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>
=============================
Конечно, можно намного короче, но я взял его где-то готовый, подправил и все уже несколько лет работает в автоматическом режиме..