这是一个晚回答!-dNOSAFER
的问题阻止了我使用其他解决方案,所以我做了以下操作:
使用Python将JPG文件作为二进制读取并将其转换为字符串,与/ASCIIHexDecode
兼容:
''.join(["%02x" % ord(c) for c in open(filename, "rb").read()])
然后,不要从PostScript文件中读取和解码图像文件,而是将上述计算出的字符串粘贴到PostScript文件中,并通过/ASCIIHexDecode
和/DCTDecode
进行过滤:
(ffd8ffe000104a46494600010102002700270000ffdb004300030202020202030202020303030304060404040404080606050609080a0a090809090a0c0f0c0a0b0e0b09090d110d0e0f101011100a0c12131210130f101010ffdb00430103030304030408040408100b090b1010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010ffc00011080010001003011100021101031101ffc400160001010100000000000000000000000000060507ffc40026100002020201030207000000000000000001020304051106071221001315163132414252ffc400160101010100000000000000000000000000070403ffc4002911000201030105090100000000000000000102030004210711123151531314324142617381d1d3ffda000c03010002110311003f00de311d00e0478be19acddc79b0f8ba734aef8aa8a59a4af1c9bdc96159beef275e4efd1ccfa5f2aceea2f8e09f41e7f252a47ab4c4093ba71ceced387b7828b724e87705b588c8478ecac114e28d89e36f83d65d7643ee7eb60b03a23f1f5dff002daaacf4ae479954df1e3d33fd2b593599628d89b0071d5fae9d3bc5750b8a3f1ae3cc9cd3031b4789c689236ce568de374af543ab21b51b2b03138208076a3cef4c8b935acaf3bb05c12685036e285e550b3bccf8a41c7b2327ce78c9a6188b917b2995ab20676a8102af6dc76624c680011f9d8f0005095da5b491ccaec303f0d4f292ebba01cecf23cc57ffd9>)
/ASCIIHexDecode
filter % ascii to bytes
0 dict
/DCTDecode % jpg to explicit
filter
上面的代码片段替换了@Hath995答案中的(myJPEG500x133.jpg) (r) file /DCTDecode filter
,这对编程非常有帮助。
如果你想要除了JPEG以外的RGB格式(即:你需要一些postscript没有解码器的格式),并且可以使用Python来准备你的postscript文件,你可以像下面这样使用PIL(它会忽略透明度字节,在postscript中是一个打开/关闭操作):
import PIL.Image
i = PIL.Image.open("/tmp/from-template.png")
import itertools
''.join(["%02x" % g
for g in itertools.chain.from_iterable(
k[:3] for k in i.getdata())])
对于索引文件,我不确定,但是解决起来肯定不难。