转载 java——最快捷的将输入流转换为String的方法

原文地址: https://weblogs.java.net/blog/pat/archive/2004/10/stupid_scanner_1.html

正则表达式中, \A是指一个字符串的开头,可能大家用惯了 ^,而忽略了这个 \A, 但是^其实是指一行的开始,而不管一个字符串里面包含多少行, \A 都只匹配第一行的开头。
那么我们可以用 \A 做点什么呢?,看下面这个例子:
static String convertStreamToString(java.io.InputStream is) {
    java.util.Scanner s =  new java.util.Scanner(is).useDelimiter("\\A");
     return s.hasNext() ? s.next() : "";
}
相信大家都看懂了,用 \A作为分隔符,那么得到的当然就只有一个token,那就是整个字符串了。再配合Scanner,就轻易的将一个输入流转换为一个字符串了。
注意当需要做编码转换时,Scanner是有支持编码参数的构造方法的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将Excel文件输入流转换为PNG文件输入,需要进行以下步骤: 1. 使用Apache POI库读取Excel文件输入,将其转换为Workbook对象。 2. 使用Apache Batik库将Workbook对象转换为SVG字符串。 3. 使用Apache Batik库将SVG字符串转换为PNG文件输出。 以下是Java代码示例,可以实现将Excel文件输入流转换为PNG文件输入: ```java import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.InputStream; import java.io.OutputStream; import org.apache.batik.dom.svg.SVGDOMImplementation; import org.apache.batik.svggen.SVGGeneratorContext; import org.apache.batik.svggen.SVGGraphics2D; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.WorkbookFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; public class ExcelToPNGConverter { public static InputStream convert(InputStream excelStream) throws Exception { // Read the Excel file input stream Workbook workbook = WorkbookFactory.create(excelStream); // Create a new SVG document String svgNS = SVGDOMImplementation.SVG_NAMESPACE_URI; Document document = SVGDOMImplementation.getDOMImplementation().createDocument(svgNS, "svg", null); Element svgRoot = document.getDocumentElement(); // Generate SVG from the Excel file SVGGeneratorContext ctx = SVGGeneratorContext.createDefault(document); SVGGraphics2D graphics = new SVGGraphics2D(ctx, false); graphics.setSVGCanvasSize(workbook.getSpreadsheetVersion().getLastRowIndex(), workbook.getSpreadsheetVersion().getLastColumnIndex()); workbook.getSheetAt(0).draw(graphics); graphics.getRoot(svgRoot); // Convert SVG to PNG ByteArrayOutputStream pngStream = new ByteArrayOutputStream(); org.apache.batik.transcoder.Transcoder transcoder = new org.apache.batik.transcoder.image.PNGTranscoder(); org.apache.batik.transcoder.TranscoderInput transcoderInput = new org.apache.batik.transcoder.TranscoderInput(document); org.apache.batik.transcoder.TranscoderOutput transcoderOutput = new org.apache.batik.transcoder.TranscoderOutput(pngStream); transcoder.transcode(transcoderInput, transcoderOutput); return new ByteArrayInputStream(pngStream.toByteArray()); } } ``` 使用方式: ```java InputStream excelStream = new FileInputStream("input.xlsx"); InputStream pngStream = ExcelToPNGConverter.convert(excelStream); ``` 注意:需要添加以下依赖库: - Apache POI - Apache Batik - XML Graphics Commons
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值