加载大量的xml数据 使用压缩方法解决(当然较小时也可以压缩)

 

[新闻资讯] 将XML保存为二进制数据

  • 资讯类型: 翻译
  • 来源页面: http://www.ghostwire.com/blog/archives/as3-saving-xml-as-binary/
  • 资讯原标题: Saving XML As Binary
  • 资讯原作者: sunny

     


    如果你的应该程序必须在运行期间加载一个外部大且冗长的XML文件时,这个方案可能是有用的,通过将XML保存为二进制,你可以压缩数据得到一个较小的文件,当然,你可以得到的压缩的数量取决于数据的复杂性,但它通常超过50%(保守估计)。
      无可否认的,经压缩的二进制格式的XML数据违背了摆在首位采用XML的初衷——数据可读性。因此,在程序进行前你将必须先决择哪一种更为重要。也许真实的外部数据才是你想要的——允许数据被具体化,可以改变数据而无需重新编译SWF,然而,或许你更喜欢数据不可编辑。
    将XML转换为二进制数据(ByteArray)
    首先,我们看看XML数据如何存储在ByteArray中。下面的代码假定您已经有名为“xmlData”字符串值变量存储XML数据:
    1. var data:ByteArray = new ByteArray();
    2. data.writeUTFBytes(xmlData); // xmlData is original XML string
    3. data.compress();
    保存文件
    现在,您已经有二进制数据ByteArray对象,可以将该对象作为原始数据保存为文件。你可以以下任意一种方式实现。
    (一)发送到服务器脚本;
    (二)用AIR API保存到本地存储;或
    (三)使用Flash Player 10 API保存到本地存储。
    我 们会用(三),因为是这是每一个Flash开发人员最容易的方案。这个类将会使用flash.net.FileReference。FileReference.save()方法只有在Flash Player 10时才可用。它允许你保存FileReference对象中的数据至本地。
    1. function on_buttonClick(evt:MouseEvent):void
    2. {
    3.         var data:ByteArray = new ByteArray();
    4.         data.writeUTFBytes(xmlData); // xmlData is original XML string
    5.         data.compress();
    6.         new FileReference().save(data, "bindata.xml"); // default name "bindata.xml"
    7. }

     

    save()方法将打一个本地对话框——输入文件名选择存放位置后将会把XML数据存储至本地。注意保存的文件须以“.xml”作为后缀,但是该文件不是可读地——用文本编辑器打开该文件你看到的是些垃圾数据。
    加载二进制XML
    加载二进制文件同正常的文本XML文件加载方式一样:

    1. var ldr:URLLoader        = new URLLoader();
    2. ldr.dataFormat        = URLLoaderDataFormat.BINARY; // ** make sure you do this **
    3. ldr.addEventListener(Event.COMPLETE, on_XML);
    4. ldr.addEventListener(IOErrorEvent.IO_ERROR, on_XML);
    5. ldr.load(new URLRequest(pathToXMLFile));
    复制代码
    因此,代码同正常的文本XML文件加载方式一样,除了需要将dataFormat设置为URLLoaderDataFormat.BINARY。即使你加载一个普通的文本XML文件,上面的代码也会工作得很好。
    将二进制数据转换为XML
    二进制XML文件加载成功后,将二进制数据转换为文本XML。
    1. var xmlData:XML;
    2. function on_XML(evt:Event):void
    3. {
    4.         if (evt.type == Event.COMPLETE)
    5.         {
    6.                 var data:* = URLLoader(evt.target).data;
    7.                 if (data is ByteArray)
    8.                 {
    9.                         try
    10.                         {
    11.                                 ByteArray(data).uncompress();
    12.                         }
    13.                         catch(e:Error)
    14.                         {
    15.                         }
    16.                 }
    17.                 xmlData = XML(data);
    18.         }
    19. }
    上面的代码,你的应用程序将能够同时处理文本XML和二进制XML文件。因此,此代码你仍可以使用,即使您目前没有使用XML存储为压缩的二进制数据。如果在以后您决定将XML采用二进制压缩格式,该应用程序也能很好的处理。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用 Aspose 将 PDF 分页转换为图片后再合并成 PDF 并压缩的代码示例如下: ``` import com.aspose.pdf.*; // Load the PDF document Document pdfDocument = new Document("input.pdf"); // Loop through all the pages in the PDF for (int pageNumber = 1; pageNumber <= pdfDocument.getPages().size(); pageNumber++) { // Get the current page Page pdfPage = pdfDocument.getPages().get_Item(pageNumber); // Convert the page to image BufferedImage image = pdfPage.convertToImage(); // Save the image ImageIO.write(image, "jpg", new File("page_" + pageNumber + ".jpg")); } // Create a new PDF document Document newPdfDocument = new Document(); // Loop through all the images for (int pageNumber = 1; pageNumber <= pdfDocument.getPages().size(); pageNumber++) { // Get the current image BufferedImage image = ImageIO.read(new File("page_" + pageNumber + ".jpg")); // Create a new page in the new PDF document Page newPdfPage = newPdfDocument.getPages().add(); // Add the image to the page newPdfPage.getResources().getImages().add(image); } // Save the new PDF document newPdfDocument.save("output.pdf"); // Compress the PDF document newPdfDocument.compress(); // Save the compressed PDF document newPdfDocument.save("output_compressed.pdf"); ``` 需要注意的是,上面的代码需要 Aspose.PDF for Java 库的支持,请确保在项目中导入了该库。 ### 回答2: Java pdf使用aspose分页转图片后再合成pdf再压缩pdf的代码可以按照以下步骤来实现: 第一步:导入aspose-pdf依赖 首先,需要在Java项目中导入aspose-pdf的依赖。可以在项目的pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.aspose</groupId> <artifactId>aspose-pdf</artifactId> <version>20.11</version> </dependency> ``` 第二步:分页转图片 使用aspose-pdf提供的API,将PDF文件按页分解为多个图片。可以使用以下代码实现: ```java // 加载PDF文件 Document pdfDocument = new Document("input.pdf"); // 获取总页数 int pageCount = pdfDocument.getPages().size(); for (int pageIndex = 1; pageIndex <= pageCount; pageIndex++) { // 生成对应页码的图片文件 String imageFilePath = "page" + pageIndex + ".jpg"; ImageSaveOptions options = new ImageSaveOptions(SaveFormat.JPEG); options.setPageCount(1); options.setPageIndex(pageIndex); pdfDocument.save(imageFilePath, options); } ``` 第三步:合成PDF 将上一步生成的多个图片文件合成为一个PDF文件。可以使用以下代码实现: ```java // 创建新的PDF文档 Document newPdfDocument = new Document(); // 添加每个图片文件作为一个页码 for (int pageIndex = 1; pageIndex <= pageCount; pageIndex++) { String imageFilePath = "page" + pageIndex + ".jpg"; Page pdfPage = newPdfDocument.getPages().add(); pdfPage.getPageInfo().setMargin(new MarginInfo(0, 0, 0, 0)); Image image = new Image(); image.setFile(imageFilePath); pdfPage.getParagraphs().add(image); } // 保存合成的PDF文件 newPdfDocument.save("output.pdf"); ``` 第四步:压缩PDF 在合成的PDF文件中,可能存在一些冗余信息,可以通过压缩来减小文件大小。可以使用以下代码实现: ```java Document pdfDocument = new Document("output.pdf"); pdfDocument.setOptimizeSize(true); pdfDocument.optimize(); // 保存压缩后的PDF文件 pdfDocument.save("compressed.pdf"); ``` 通过以上的代码,可以实现Java pdf使用aspose分页转图片后再合成pdf再压缩pdf的功能。简单说就是先将PDF文件分解为多个图片,然后将这些图片合成为一个新的PDF文件,最后再对新的PDF文件进行压缩,减小文件大小。 ### 回答3: 使用Aspose来实现Java PDF分页转图片、合成PDF以及压缩PDF的代码。 ```java import com.aspose.pdf.Document; import com.aspose.pdf.ImagePlacementAbsorber; import com.aspose.pdf.ImagePlacementPropertiesCollection; import com.aspose.pdf.Page; import com.aspose.pdf.Rectangle; import com.aspose.pdf.devices.Resolution; import com.aspose.pdf.devices.TiffDevice; import java.io.File; import java.io.FileOutputStream; import java.util.ArrayList; import java.util.List; public class PdfUtil { // 分页转图片 public static List<String> convertPdfToImage(String pdfFilePath, String imageFolder) { List<String> imagePaths = new ArrayList<>(); try { Document document = new Document(pdfFilePath); int pageCount = document.getPages().size(); for (int i = 1; i <= pageCount; i++) { Page page = document.getPages().get_Item(i); String imagePath = imageFolder + File.separator + "page_" + i + ".tiff"; FileOutputStream imageStream = new FileOutputStream(imagePath); Resolution resolution = new Resolution(300); TiffDevice tiffDevice = new TiffDevice(resolution); tiffDevice.process(page, imageStream); imageStream.close(); imagePaths.add(imagePath); } } catch (Exception ex) { ex.printStackTrace(); } return imagePaths; } // 合成PDF public static void mergeImagesToPdf(List<String> imagePaths, String mergedPdfPath) { try { Document mergedPdf = new Document(); for (String imagePath : imagePaths) { Page page = mergedPdf.getPages().add(); page.getPageInfo().setMargin(new Rectangle(0, 0, 0, 0)); ImagePlacementAbsorber absorber = new ImagePlacementAbsorber(); page.accept(absorber); ImagePlacementPropertiesCollection properties = absorber.getImagePlacementProperties(); page.getResources().getImages().add(imagePath); properties.get_Item(properties.size()).setRectangle(new Rectangle(page.getPageInfo().getWidth(), page.getPageInfo().getHeight())); } mergedPdf.save(mergedPdfPath); } catch (Exception ex) { ex.printStackTrace(); } } // 压缩PDF public static void compressPdf(String pdfFilePath, String compressedPdfPath) { try { Document document = new Document(pdfFilePath); document.optimizeSize(); document.save(compressedPdfPath); } catch (Exception ex) { ex.printStackTrace(); } } public static void main(String[] args) { String pdfFilePath = "input.pdf"; String imageFolder = "images"; String mergedPdfPath = "merged.pdf"; String compressedPdfPath = "compressed.pdf"; // 分页转图片 List<String> imagePaths = convertPdfToImage(pdfFilePath, imageFolder); // 合成PDF mergeImagesToPdf(imagePaths, mergedPdfPath); // 压缩PDF compressPdf(mergedPdfPath, compressedPdfPath); } } ``` 这段代码利用Aspose库来实现了对PDF文件进行分页转图片、合成PDF以及压缩PDF的功能。具体实现过程为先将PDF文件的每一页转换为图片(TIFF 格式),然后将这些图片合成为一个新的PDF文件,最后对新生成的PDF进行压缩。在代码中使用了Aspose.PDF的Document类来处理PDF文件,TiffDevice类将PDF中的每一页转换为TIFF格式的图片,ImagePlacementAbsorber和ImagePlacementPropertiesCollection类用于合成PDF文件,而compressPdf方法则是利用optimizeSize方法对PDF文件进行压缩

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值