300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 读取FTP上的excel文件 并写入数据库

读取FTP上的excel文件 并写入数据库

时间:2022-11-28 23:40:51

相关推荐

读取FTP上的excel文件 并写入数据库

今天遇到一些问题,需要从ftp上读取一些excel文件,并需要将excel中的数据写入到数据库,这样就可以通过管理页面查看这些数据。

我将相关工作分为三步,1、从ftp上读取相关文件,并将excel文件下载到本地。2、读取本地下载完成的excel,读取相关信息 3、将读取的信息存储到数据库中。

1、获取java操作ftp操作,首先要从maven仓库/artifact/commons-net/commons-net 下载相应的jar包,apache commons net 提供了相应的接口。

/*** 获取FTPClient对象* * @param ftpHost* FTP主机服务器* @param ftpPassword* FTP 登录密码* @param ftpUserName* FTP登录用户名* @param ftpPort* FTP端口 默认为21* @return*/public static FTPClient getFTPClient(String ftpHost, String ftpUserName, String ftpPassword, int ftpPort){FTPClient ftpClient = new FTPClient();try{ftpClient = new FTPClient();ftpClient.connect(ftpHost, ftpPort);// 连接FTP服务器ftpClient.login(ftpUserName, ftpPassword);// 登陆FTP服务器if (!FTPReply.isPositiveCompletion(ftpClient.getReplyCode())){log.info("未连接到FTP,用户名或密码错误。");ftpClient.disconnect();} else{log.info("FTP连接成功。");}} catch (SocketException e){e.printStackTrace();log.info("FTP的IP地址可能错误,请正确配置。");} catch (IOException e){e.printStackTrace();log.info("FTP的端口错误,请正确配置。");}return ftpClient;}

public static void main(String [] args) throws IOException{String ftp_ipadd = "127.0.0.1";//ftp 地址String ftp_user = "guest";//ftp 登录帐号String ftp_passwd = "guest";//ftp 登录帐号密码int ftpport = 21;//ftp端口,默认为21 FTPClient ftpClient = this.getFTPClient(ftp_ipadd, ftp_user, ftp_passwd, ftpport);log.info(String.valueOf(ftpClient.getReplyCode()));ftpClient.setControlEncoding("UTF-8"); // 中文支持ftpClient.setFileType(FTPClient.BINARY_FILE_TYPE);//设置文件类型ftpClient.enterLocalPassiveMode();//设置ftp 模式,有被动模式和活动模式,这里设置为被动模式String datestr = DateUtil.getyesterdayStr();//获取前一天的日期格式为0921ftpClient.changeWorkingDirectory("/data/" + datestr + "/JD/");//设置ftp文件所在的目录FTPFile [] files = ftpClient.listFiles();log.info(files.toString());for (int i = 0; i < files.length; i++){log.info(files[i].getName());File localFile = new File("d:\\download\\" + datestr + "\\" + files[i].getName());//设置本地下载的目录File fileparent = localFile.getParentFile();//本地下载目录下的文件夹,如果不存在则创建if (!fileparent.exists()){fileparent.mkdirs();}OutputStream os = new FileOutputStream(localFile);//输出到本地文件流ftpClient.retrieveFile(files[i].getName(), os);//下载文件到本地 os.close();}ftpClient.logout();//关闭ftp链接}

这里只写了demo 不做代码优化了。

2、读取本地的excel文件,java读取excel主要有两种方式jxl 和 poi, jxl只能读取以前的版本,但效率要高于poi,内存占用率也相对低(这里我也没有验证,导入量少基本没感觉),poi则提供了两种方式分别支持和,HSSF方式支持,XSSF方式支持。这里我使用jxl读取xls结尾的文件,使用XSSF读取xlsx结尾的文件。同样如果想使用两种方法都需要到maven仓库下载相应的jar包。

/*** 读取excel文件* * @param args*/public static void readExcel(File filePath){String extString = filePath.getName().substring(filePath.getName().lastIndexOf("."));//读取文件并判断文件类型InputStream is = null;try{is = new FileInputStream(filePath);if (".xls".equals(extString)){jxlExcel(filePath);//这里执行jxl方法读取excel} else if (".xlsx".equals(extString)){xssfExcel(filePath);//这里执行xssf方法读取excel }} catch (FileNotFoundException e){e.printStackTrace();} catch (IOException e){e.printStackTrace();}}/*** 使用jxl方式读取excel * @param filePath*/public static void jxlExcel(File filePath){try{Workbook workbook = Workbook.getWorkbook(filePath);Sheet sheet = workbook.getSheet(0);int rowNums = sheet.getRows();// 获取excel总行数int columns = sheet.getColumns();for (int i = 1; i <= rowNums; i++){for (int j = 0; j < columns; j++){log.info(sheet.getCell(i, j).toString());}}} catch (BiffException e){// TODO Auto-generated catch block e.printStackTrace();} catch (IOException e){// TODO Auto-generated catch block e.printStackTrace();}}public static void xssfExcel(File filePath){try{XSSFWorkbook xssfworkbook = new XSSFWorkbook(new FileInputStream(filePath));XSSFSheet xssfsheet = xssfworkbook.getSheetAt(0);int rowNums = xssfsheet.getLastRowNum();// 当前sheet总共有多少行int columns = xssfsheet.getRow(0).getPhysicalNumberOfCells();// 当前sheet总共有多少列for (int i = 1; i <= rowNums; i++){Row row = xssfsheet.getRow(i);for (int j = 0; j < columns; j++){log.info(row.getCell(j).toString());}}} catch (FileNotFoundException e){// TODO Auto-generated catch block e.printStackTrace();} catch (IOException e){// TODO Auto-generated catch block e.printStackTrace();}}

3、存入数据库,这里就不多说了。

关于ftp下载和读取excle其实也是常规的操作,只是需要 认真些就可以,当然可以把相关操作封装为util文件,使用的时候直接调用会更方便些。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。