JAVA)简述如何在控制台打印出一个excel文件的全部内容,(简述类结构和编码过程?

Python013

JAVA)简述如何在控制台打印出一个excel文件的全部内容,(简述类结构和编码过程?,第1张

类结构:

首先要定义一个类,该类负责读取Excel文件并将其内容转换成可以在控制台打印的字符串。该类应该具有以下几个成员:

1. 一个构造函数,用于接受Excel文件的路径,并将其加载到内存中。

2. 一个成员变量,用于保存Excel文件的内容。

3. 一个方法,用于将Excel文件的内容转换为可以在控制台打印的字符串。

编码过程:

首先,从构造函数开始,使用Java POI库中提供的API来读取Excel文件,并将其内容存储在成员变量中。

接下来,实现将Excel文件内容转换为可以在控制台输出的字符串的方法。首先使用POI库中提供的API来读取Excel文件的行和列,将其转换为字符串。然后,使用换行符将每一行的字符串连接起来,最终得到一个可以在控制台输出的字符串。

1、Desktop.getDesktop().print(new File("c:/123.jpg"))

2、private void printFileAction()

{

//构造一个文件选择器,默认为当前目录

JFileChooser fileChooser = new JFileChooser(SystemProperties.USER_DIR)

int state = fileChooser.showOpenDialog(this)//弹出文件选择对话框

if (state == fileChooser.APPROVE_OPTION)//如果用户选定了文件

{

File file = fileChooser.getSelectedFile()//获取选择的文件

//构建打印请求属性集

PrintRequestAttributeSet pras = new HashPrintRequestAttributeSet()

//设置打印格式,因为未确定文件类型,这里选择AUTOSENSE

DocFlavor flavor = DocFlavor.INPUT_STREAM.AUTOSENSE

//查找所有的可用打印服务

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()

}

}

}

}

在上面的示例中,因尚未确定文件的类型,所以将指定文件的打印格式定义为DocFlavor.INPUT_STREAM.AUTOSENSE。事实上,如果在进行打印之前,就已确定地知道文件的格式,如为GIF,就应定义为DocFlavor.INPUT_STREAM.GIF ;如为PDF,就应该定义为DocFlavor.INPUT_STREAM.PDF;如为纯ASCII文件,就可以定义为 DocFlavor.INPUT_STREAM.TEXT_HTML_US_ASCII。等等。jdk1.4的javax.print.DocFlavor提供了极为丰富的文件流类型,你可以根据具体的应用需求进行合适的选择。

HSSFPrintSetup printSetup = sheet.getPrintSetup()2 printSetup.setVResolution((short) 600) printSetup.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE) //A4纸张打印4 printSetup.setLandscape(true) //横向打印