- 浏览: 1547228 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (525)
- SEO (16)
- JAVA-EE-Hibernate (6)
- JAVA-EE-Struts (29)
- JAVA-EE-Spring (15)
- Linux (37)
- JAVA-SE (29)
- NetWork (1)
- CMS (14)
- Semantic Research (3)
- RIA-Flex (0)
- Ajax-Extjs (4)
- Ajax-Jquery (1)
- www.godaddy.com (0)
- SSH (34)
- JavaScript (6)
- SoftwareEngineer (9)
- CMMI (0)
- IDE-Myeclipse (3)
- PHP (1)
- Algorithm (3)
- C/C++ (18)
- Concept&Items (2)
- Useful WebSite (1)
- ApacheServer (2)
- CodeReading (1)
- Socket (2)
- UML (10)
- PowerDesigner (1)
- Repository (19)
- MySQL (3)
- SqlServer (0)
- Society (1)
- Tomcat (7)
- WebService (5)
- JBoss (1)
- FCKeditor (1)
- PS/DW/CD/FW (0)
- DesignPattern (11)
- WebSite_Security (1)
- WordPress (5)
- WebConstruction (3)
- XML|XSD (7)
- Android (0)
- Project-In-Action (9)
- DatabaseDesign (3)
- taglib (7)
- DIV+CSS (10)
- Silverlight (52)
- JSON (7)
- VC++ (8)
- C# (8)
- LINQ (1)
- WCF&SOA (5)
- .NET (20)
- SOA (1)
- Mashup (2)
- RegEx (6)
- Psychology (5)
- Stock (1)
- Google (2)
- Interview (4)
- HTML5 (1)
- Marketing (4)
- Vaadin (2)
- Agile (2)
- Apache-common (6)
- ANTLR (0)
- REST (1)
- HtmlAnalysis (18)
- csv-export (3)
- Nucth (3)
- Xpath (1)
- Velocity (6)
- ASP.NET (9)
- Product (2)
- CSS (1)
最新评论
-
lt26w:
理解成门面模式应该比较容易明白吧
FacadePattern-Java代码实例讲解 -
lt26w:
看下面的例子比较明白.
FacadePattern-Java代码实例讲解 -
javaloverkehui:
这也叫文档,别逗我行吗,也就自己看看。
HtmlCleaner API -
SE_XiaoFeng:
至少也应该写个注释吧。
HtmlCleaner API -
jfzshandong:
...
org.springframework.web.filter.CharacterEncodingFilter 配置
入文件若为二进制格式的csv或xls文件需要用jxl.jar包来解析,
若文件为文本格式逗号分隔的csv文件则需要用opencsv.jar包来解析。
如何区分文件为二进制格式,简单的方法可以右键使用记事本打开,若为乱码则为二进制文件,这样的文件只能使用office的excel工具打开;而 文本格式逗号分隔的csv文件使用记事本就可以打开。
下面为导入两种格式文件的代码示例:
1. 导入文本格式逗号分隔的csv文件
Java代码
- import au.com.bytecode.opencsv.CSVReader;
Java代码
- import au.com.bytecode.opencsv.CSVReader;
import au.com.bytecode.opencsv.CSVReader;
Java代码
- public void importCsvFile() {
- CSVReader csvReader = null ;
- try {
- csvReader = new CSVReader( new FileReader(importFile), ',' ); //importFile为要导入的文本格式逗号分隔的csv文件,提供getXX /setXX方法
- if (csvReader != null ){
- //first row is title, so past
- csvReader.readNext();
- String[] csvRow = null ; //row
- while ((csvRow = csvReader.readNext()) != null ){
- for ( int i = 0 ; i<csvRow.length; i++){
- String temp = csvRow[i];
- switch (i) {
- case 0 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanName(temp);
- }
- break ;
- case 1 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanEmail(temp);
- }
- break ;
- default :
- break ;
- }
- }
- //保存linkman到数据库
- if (linkman.getLinkmanName() != null && linkman.getLinkmanEmail() != null ){
- EmailLinkmanAPI.insertLinkman(linkman);
- }
- }
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
Java代码
- public void importCsvFile() {
- CSVReader csvReader = null ;
- try {
- csvReader = new CSVReader( new FileReader(importFile), ',' ); //importFile 为要导入的文本格式逗号分隔的csv文件,提供getXX/setXX方法
- if (csvReader != null ){
- //first row is title, so past
- csvReader.readNext();
- String[] csvRow = null ; //row
- while ((csvRow = csvReader.readNext()) != null ){
- for ( int i = 0 ; i<csvRow.length; i++){
- String temp = csvRow[i];
- switch (i) {
- case 0 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanName(temp);
- }
- break ;
- case 1 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanEmail(temp);
- }
- break ;
- default :
- break ;
- }
- }
- //保存linkman到数据库
- if (linkman.getLinkmanName() != null && linkman.getLinkmanEmail() != null ){
- EmailLinkmanAPI.insertLinkman(linkman);
- }
- }
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
public void importCsvFile() { CSVReader csvReader = null; try { csvReader = new CSVReader(new FileReader(importFile),',');//importFile为要导入的文本格式逗号分隔的csv文件,提供getXX/setXX方法 if(csvReader != null){ //first row is title, so past csvReader.readNext(); String[] csvRow = null;//row while ((csvRow = csvReader.readNext()) != null){ for (int i =0; i<csvRow.length; i++){ String temp = csvRow[i]; switch (i) { case 0: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanName(temp); } break; case 1: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanEmail(temp); } break; default: break; } } //保存linkman到数据库 if(linkman.getLinkmanName() != null && linkman.getLinkmanEmail() != null){ EmailLinkmanAPI.insertLinkman(linkman); } } } } catch (Exception e) { e.printStackTrace(); } }
2. 二进制格式的csv或xls文件
Java代码
- import jxl.Sheet;
- import jxl.Workbook;
Java代码
- import jxl.Sheet;
- import jxl.Workbook;
import jxl.Sheet; import jxl.Workbook;
Java代码
- public void importXlsFile() {
- Workbook book = null ;
- try {
- book = Workbook.getWorkbook(importFile); //importFile为要导入的 xls文件,或二进制的csv文件,提供getXX/setXX方法
- } catch (Exception e) {
- e.printStackTrace();
- }
- if (book != null ){
- int sheetNo = book.getNumberOfSheets();
- for ( int i = 0 ; i < sheetNo; i++){
- Sheet sheet=book.getSheet(i);
- int rowNum = sheet.getRows();
- int colNum = sheet.getColumns();
- //first row is title, so past
- for ( int r = 1 ; r < rowNum; r++){ //行
- for ( int c = 0 ; c < colNum;c++){ //列
- String temp = sheet.getCell(c,r).getContents();
- switch (c) {
- case 0 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanName(temp);
- }
- break ;
- case 1 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanEmail(temp);
- }
- break ;
- default :
- break ;
- }
- }
- //保存linkman到数据库
- if (linkman.getLinkmanName() != null && linkman.getLinkmanEmail() != null ){
- EmailLinkmanAPI.insertLinkman(linkman);
- }
- }
- }
- }
- }
Java代码
- public void importXlsFile() {
- Workbook book = null ;
- try {
- book = Workbook.getWorkbook(importFile);//importFile为要导入的xls文件,或二进制的csv文件,提供getXX/setXX方法
- } catch (Exception e) {
- e.printStackTrace();
- }
- if (book != null ){
- int sheetNo = book.getNumberOfSheets();
- for ( int i = 0 ; i < sheetNo; i++){
- Sheet sheet=book.getSheet(i);
- int rowNum = sheet.getRows();
- int colNum = sheet.getColumns();
- //first row is title, so past
- for ( int r = 1 ; r < rowNum; r++){ //行
- for ( int c = 0 ; c < colNum;c++){ //列
- String temp = sheet.getCell(c,r).getContents();
- switch (c) {
- case 0 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanName(temp);
- }
- break ;
- case 1 :
- if (StringUtils.isNotEmpty(temp)){
- linkman.setLinkmanEmail(temp);
- }
- break ;
- default :
- break ;
- }
- }
- //保存linkman到数据库
- if (linkman.getLinkmanName() != null && linkman.getLinkmanEmail() != null ){
- EmailLinkmanAPI.insertLinkman(linkman);
- }
- }
- }
- }
- }
public void importXlsFile() { Workbook book = null; try { book = Workbook.getWorkbook(importFile);//importFile为要导入的xls文件,或二进制的csv文件,提供getXX/setXX方法 } catch (Exception e) { e.printStackTrace(); } if(book != null){ int sheetNo = book.getNumberOfSheets(); for(int i = 0; i < sheetNo; i++){ Sheet sheet=book.getSheet(i); int rowNum = sheet.getRows(); int colNum = sheet.getColumns(); //first row is title, so past for(int r = 1; r < rowNum; r++){//行 for(int c = 0; c < colNum;c++){//列 String temp = sheet.getCell(c,r).getContents(); switch (c) { case 0: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanName(temp); } break; case 1: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanEmail(temp); } break; default: break; } } //保存linkman到数据库 if(linkman.getLinkmanName() != null && linkman.getLinkmanEmail() != null){ EmailLinkmanAPI.insertLinkman(linkman); } } } } }
附件为两种导入方法需要用到的jar包
相关推荐
综上所述,Java导入Excel文件涉及的关键技术包括Apache POI库的使用,对HSSF和XSSF的理解,以及对CSV文件处理的技巧。通过熟练掌握这些知识,你可以编写出高效且健壮的文件导入程序,满足各种需求。
"java导入Excel需要的jar包"这个话题,就是关于在Java项目中使用特定的jar包来处理Excel文件。下面将详细介绍相关的知识点。 1. **Apache POI**: Apache POI 是一个开源项目,专门用于处理Microsoft Office格式的...
除了Apache POI,还有其他的Java库可以读取Excel文件,如JExcelAPI(只支持.xls)、OpenCSV(主要用于CSV文件,但也能处理Excel)以及jOOQ的Excel模块等。 6. **实际应用** 在实际开发中,读取Excel文件常用于数据...
读取CSV文件是将这些数据导入到系统中的关键步骤,可以使用Java的内置库如OpenCSV或者Apache Commons CSV来实现。 Excel文件,通常以.xlsx或.xls为扩展名,是由Microsoft Excel创建的电子表格文件,用于存储和处理...
标题中的“导入excel文件的所有jar包”意味着这个压缩包包含了处理Excel文件所需的一系列Java库,也就是JAR(Java Archive)文件。在Java编程中,JAR文件是将多个类文件打包成一个单一的可执行文件,便于分发、部署...
本示例主要探讨如何在程序中实现Excel(包括2003和2007版本)及CSV文件的导入与导出功能。以下将详细介绍相关知识点。 一、Excel文件处理 1. **Apache POI库**:对于Java开发者,Apache POI是一个非常流行的API,...
- OpenCSV:虽然主要用于CSV文件,但在特定情况下也可以处理Excel。 - Apache POI的扩展库,如JFreeChart,可以用于创建复杂的图表。 总之,使用Java和Apache POI库可以高效地实现Excel数据的读取和导入。在实际...
除了Apache POI和JExcelAPI,还有其他一些库,如OpenCSV(主要用于CSV文件,但也可处理Excel),以及Spire.XLS Java库,它们提供了不同的特性和使用方式,可以根据项目需求选择合适的工具。 四、性能与选择 Apache...
OpenCSV是一个轻量级的Java库,主要用于处理CSV(逗号分隔值)文件。CSV是一种简单但广泛应用的数据交换格式,它通常用于导入或导出表格数据。使用OpenCSV,你可以轻松地读取和写入CSV文件。例如,以下代码展示了...
通过Apache POI库读取和比较Excel数据,借助OpenCSV进行CSV文件操作,以及实现CSV与Excel的相互转换,这些都是Java开发中的重要技能。在实际应用中,要结合项目需求,灵活运用这些工具和方法,同时注意代码的健壮性...
- OpenCSV:专注于CSV文件,适合简单的表格数据。 - Apache Commons CSV:Apache的另一个CSV处理库,功能更强大。 - JExcelApi的替代品:如Apache POI,因为JExcelApi不再积极维护。 通过掌握以上知识,开发者...
3. 其他库:除了Apache POI和JExcelAPI,还有一些其他库,如OpenCSV(主要用于CSV文件,但也可处理Excel),以及Spire.XLS等商业库,提供更丰富的功能和更好的性能。 4. 性能优化: - 使用SXSSF(Streaming ...
例如,Apache Commons CSV库和OpenCSV都是广泛使用的库,它们提供API来读取、写入CSV文件,可以方便地进行大数据导入和导出操作。下面是一个使用Apache Commons CSV库将Excel文件转换为CSV的基本步骤: 1. 添加依赖...
3. **使用第三方库**:由于Java标准库不包含内置的表格处理功能,因此通常会依赖于第三方库,如Apache POI(用于处理Microsoft Office格式,包括Excel)、OpenCSV(用于CSV文件)或JExcelApi(通用的电子表格处理库...
- OpenCSV:虽然主要针对CSV文件,但也可以处理Excel文件的简单读写。 2. **使用Apache POI操作Excel**: - **读取Excel**:首先,你需要创建一个`HSSFWorkbook`对象(对于老版本的XLS文件)或`XSSFWorkbook`对象...
在Java编程环境中,解析Excel文件是一项常见的任务,无论是处理数据导入导出,还是进行数据分析,都需要用到这个功能。本文将详细讲解如何使用Java来解析2003和2007版本的Excel文件(包括.xls和.xlsx格式)。 Excel...
ExcelUtils可能包含了读取、写入Excel的方法,比如使用Apache POI库来操作Excel文件,支持HSSFWorkbook(.xls)和XSSFWorkbook(.xlsx)格式,进行数据的导入导出。 2. **AbsImportFileService.java**:这是一个...
在Java编程环境中,处理Excel文件是一项常见的任务,特别是在数据分析、报表生成或数据导入导出等场景下。Java提供了多种库来支持对Excel的读写操作,使得开发者能够方便地进行Excel文件的处理。本篇文章将深入探讨...
以上就是关于"Excel导入工具类"涉及的关键知识点,包括Excel文件格式、Java处理Excel的库、数据读取与处理方法以及实际应用案例。在实际开发中,我们需要根据项目需求选择合适的库,并进行适当优化,确保高效、稳定...
3. OpenCSV:虽然OpenCSV主要用于CSV文件处理,但在某些情况下,也可以将其用于简单的Excel数据导出。引入的JAR文件为: - opencsv-版本号.jar 4. SheetJS Java:基于SheetJS的Java实现,可以读写XLSX和XLSB格式,...