现在已经用poi生成一个Excel文件在C盘下,名称为:客户.xls,现在要求将这个excel文件打印出来!
下面的代码是java自带的print开发包,虽然能调用打印机,但是打印的是一串英文或者乱码,不能将excel里面的内容打印出来,请问:如何打印excel文件???
package tree;import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;import javax.print.Doc;
import javax.print.DocFlavor;
import javax.print.DocPrintJob;
import javax.print.PrintService;
import javax.print.PrintServiceLookup;
import javax.print.ServiceUI;
import javax.print.SimpleDoc;import javax.print.attribute.DocAttributeSet;
import javax.print.attribute.HashDocAttributeSet;
import javax.print.attribute.HashPrintRequestAttributeSet;
import javax.print.attribute.PrintRequestAttributeSet;
import javax.swing.JFileChooser;public class TestPrintJob { /**
* @param args
*/
public static void main(String[] args) {
// TODO 自动生成方法存根
new TestPrintJob();
}
TestPrintJob(){
this.printFileAction();
}
private void printFileAction()
{
// 构造一个文件选择器,默认为当前目录
JFileChooser fileChooser = new JFileChooser();
int state = fileChooser.showOpenDialog(fileChooser);
// 弹出文件选择对话框
if (state == JFileChooser.APPROVE_OPTION)
// 如果用户选定了文件
{
File file = fileChooser.getSelectedFile();
// 获取选择的文件
// 构建打印请求属性集
PrintRequestAttributeSet pras = new HashPrintRequestAttributeSet();
// 设置打印格式,因为未确定文件类型,这里选择AUTOSENSE
DocFlavor flavor = DocFlavor.INPUT_STREAM.AUTOSENSE;
//DocFlavor flavor = DocFlavor.SERVICE_FORMATTED.PRINTABLE;
// 查找所有的可用打印服务
PrintService printService[] = PrintServiceLookup.lookupPrintServices(flavor, pras);
// 定位默认的打印服务
PrintService defaultService = PrintServiceLookup.lookupDefaultPrintService();
// 显示打印对话框
PrintService service = ServiceUI.printDialog(null, 200, 200, printService , defaultService, flavor, pras);
if (service != null)
{
try
{
DocPrintJob job = service.createPrintJob();
// 创建打印作业
FileInputStream fis = new FileInputStream(file);
// 构造待打印的文件流
DocAttributeSet das = new HashDocAttributeSet();
Doc doc = new SimpleDoc(fis, flavor, das);
// 建立打印文件格式
job.print(doc, pras);
// 进行文件的打印
} catch(Exception e)
{
e.printStackTrace();
}
}
}
}
}
下面的代码是java自带的print开发包,虽然能调用打印机,但是打印的是一串英文或者乱码,不能将excel里面的内容打印出来,请问:如何打印excel文件???
package tree;import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;import javax.print.Doc;
import javax.print.DocFlavor;
import javax.print.DocPrintJob;
import javax.print.PrintService;
import javax.print.PrintServiceLookup;
import javax.print.ServiceUI;
import javax.print.SimpleDoc;import javax.print.attribute.DocAttributeSet;
import javax.print.attribute.HashDocAttributeSet;
import javax.print.attribute.HashPrintRequestAttributeSet;
import javax.print.attribute.PrintRequestAttributeSet;
import javax.swing.JFileChooser;public class TestPrintJob { /**
* @param args
*/
public static void main(String[] args) {
// TODO 自动生成方法存根
new TestPrintJob();
}
TestPrintJob(){
this.printFileAction();
}
private void printFileAction()
{
// 构造一个文件选择器,默认为当前目录
JFileChooser fileChooser = new JFileChooser();
int state = fileChooser.showOpenDialog(fileChooser);
// 弹出文件选择对话框
if (state == JFileChooser.APPROVE_OPTION)
// 如果用户选定了文件
{
File file = fileChooser.getSelectedFile();
// 获取选择的文件
// 构建打印请求属性集
PrintRequestAttributeSet pras = new HashPrintRequestAttributeSet();
// 设置打印格式,因为未确定文件类型,这里选择AUTOSENSE
DocFlavor flavor = DocFlavor.INPUT_STREAM.AUTOSENSE;
//DocFlavor flavor = DocFlavor.SERVICE_FORMATTED.PRINTABLE;
// 查找所有的可用打印服务
PrintService printService[] = PrintServiceLookup.lookupPrintServices(flavor, pras);
// 定位默认的打印服务
PrintService defaultService = PrintServiceLookup.lookupDefaultPrintService();
// 显示打印对话框
PrintService service = ServiceUI.printDialog(null, 200, 200, printService , defaultService, flavor, pras);
if (service != null)
{
try
{
DocPrintJob job = service.createPrintJob();
// 创建打印作业
FileInputStream fis = new FileInputStream(file);
// 构造待打印的文件流
DocAttributeSet das = new HashDocAttributeSet();
Doc doc = new SimpleDoc(fis, flavor, das);
// 建立打印文件格式
job.print(doc, pras);
// 进行文件的打印
} catch(Exception e)
{
e.printStackTrace();
}
}
}
}
}
解决方案 »
免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货