- 浏览: 28630 次
- 性别:
- 来自: 武汉
-
文章分类
最新评论
-
tiger112:
aixs3GKgn4oVplJGeAI96Q.. 这个竟 ...
SSI实现 excel 与ORACLE 之间的导入导出 -
tiger112:
你是一号店的 哈哈
SSI实现 excel 与ORACLE 之间的导入导出 -
qiannancy:
...
jQuery日历组件
1.导入相应的jar包
jxl.jar antlr-2.7.2.jar commons-collections.jar commons-dbcp.jar commons-logging-1.0.4.jar freemarker-2.3.8.jar ibatis-2.3.4.726.jar ognl-2.6.11.jar spring.jar struts2-core-2.0.14.jar struts2-spring-plugin-2.0.14.jar xwork-2.0.7.jar ojbc14.jar
2.页面用freemerk
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>用户管理</title> <script> function interExcel(){ window.location.href="interExcel.action" } function goExcelToOracle(){ window.location.href="goExcelToOracle.action" } </script> </head> <body> <form> <table> <tr><td>ID</td><td>姓名</td><td>密码</td></tr><br /> <#list list?if_exists as user> <tr><td>${user.id}</td><td>${user.userName}</td><td>${user.password}</td></tr> </#list> <tr><td><input type="button" onclick="interExcel()" value="导入到Excel表中"/></td></tr> <tr><td><input type="button" onclick="goExcelToOracle()" value="Excel导入Oracle数据库"/></td></tr> </table> </form> </body> </html>
3. web.xml的配置
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>excel</display-name> <welcome-file-list> <welcome-file>user.jsp</welcome-file> </welcome-file-list> <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/applicationContext.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <filter> <filter-name>struts</filter-name> <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> </filter> <filter-mapping> <filter-name>struts</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
4.struts.xml的配置
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <constant name="struts.objectFactory" value="org.apache.struts2.spring.StrutsSpringObjectFactory"/> <package name="user" extends="struts-default" namespace="/"> <action name="getAllUser" class="userAction" method="getAllUser"> <result name="success" type="freemarker">WEB-INF/user.ftl</result> </action> <!-- 数据导入到Excel --> <action name="interExcel" class="userAction" method="interExcel"> <result name="success" type="freemarker"> /WEB-INF/user.ftl </result> <result name="error" type="freemarker"> /WEB-INF/error.ftl </result> </action> <!-- 数据从Excel导入Oracle数据库表中 --> <action name="goExcelToOracle" class="userAction" method="goExcelToOracle"> <result name="success" type="freemarker"> /WEB-INF/user.ftl </result> </action> </package> </struts>
5.applicationContext.xml的配置
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <beans> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>file:${global.config.path}jdbc_user_zhaoyun.properties</value> </list> </property> </bean> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName"> <value>${jdbc.driverClassName}</value> </property> <property name="url"> <value>${jdbc.url}</value> </property> <property name="username"> <value>${jdbc.username}</value> </property> <property name="password"> <value>${jdbc.password}</value> </property> </bean> <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"> <property name="dataSource"> <ref bean="dataSource" /> </property> <property name="configLocation"> <value>classpath:sql-map-config.xml</value> </property> </bean> <!-- 本地服务对象 --> <bean id="userDao" class="com.daizhaoyun.dao.UserDaoImpl"> <property name="client"> <ref bean="sqlMapClient" /> </property> </bean> <bean id="userService" class="com.daizhaoyun.service.UserServiceImpl"> <property name="userDao"> <ref bean="userDao" /> </property> </bean> <bean id="userAction" class="com.daizhaoyun.action.UserAction"> <property name="userService"> <ref bean="userService" /> </property> </bean> </beans>
6.jdbc_user_zhaoyun.properties 属性文件
jdbc.driverClassName=oracle.jdbc.driver.OracleDriver #jdbc.url=jdbc:oracle:thin:@192.168.129.12:1521:SID #jdbc.username=test #jdbc.password=aixs3GKgn4oVplJGeAI96Q.. jdbc.url=jdbc:oracle:thin:@192.168.129.12:1521:SID jdbc.username=test jdbc.password=test jdbc.initialSize=1 jdbc.maxActive=2 jdbc.maxIdle=1 jdbc.defaultAutoCommit=true jdbc.maxWait=5000 jdbc.removeAbandoned=true jdbc.removeAbandonedTimeout=180
7.sql-map-config.xml的配置
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-config-2.dtd"> <sqlMapConfig> <settings enhancementEnabled="true" maxTransactions="40" maxRequests="32" maxSessions="10"/> <!-- sqlmap映射文件 处理相应的sql操作--> <sqlMap resource="sqlmap-user.xml"/> </sqlMapConfig>
8.sqlmap-user.xml的配置
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd"> <sqlMap> <!-- 类型映射 --> <typeAlias alias="user" type="com.daizhaoyun.dto.User"/> <resultMap id="MenuResult" class="com.daizhaoyun.dto.User" > <result column="ID" property="id" /> <result column="USERNAME" property="userName" /> <result column="PASSWORD" property="password" /> </resultMap> <select id="getAllUser" resultClass="user"> select * from user_zhaoyun </select> <insert id="insertUser" parameterClass="user"> insert into user_zhaoyun(id,username,password) values(#id#,#userName#,#password#) </insert> </sqlMap>
9.Dto
package com.daizhaoyun.dto; public class User { private Integer id; private String userName; private String password; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
10.DAO
package com.daizhaoyun.dao; import java.util.List; import com.daizhaoyun.dto.User; public interface UserDao { public List<User> getAllUser(); public void insertUser(User user); }
package com.daizhaoyun.dao; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import com.daizhaoyun.dto.User; import com.ibatis.sqlmap.client.SqlMapClient; public class UserDaoImpl implements UserDao { SqlMapClient client; public SqlMapClient getClient() { return client; } public void setClient(SqlMapClient client) { this.client = client; } @SuppressWarnings("unchecked") @Override public List<User> getAllUser() { List<User> list = new ArrayList<User>(); try { list = client.queryForList("getAllUser"); } catch (SQLException e) { e.printStackTrace(); } return list; } @Override public void insertUser(User user) { try { //事务的开启 client.startTransaction(); client.insert("insertUser", user); client.commitTransaction(); client.endTransaction(); } catch (SQLException e) { e.printStackTrace(); } } }
11.SERVICE
package com.daizhaoyun.service; import java.util.List; import com.daizhaoyun.dto.User; public interface UserService { public List<User> getAllUser(); public void insertUser(User user); }
package com.daizhaoyun.service; import java.util.List; import com.daizhaoyun.dao.UserDao; import com.daizhaoyun.dto.User; public class UserServiceImpl implements UserService { private UserDao userDao; public UserDao getUserDao() { return userDao; } public void setUserDao(UserDao userDao) { this.userDao = userDao; } @Override public List<User> getAllUser() { return userDao.getAllUser(); } @Override public void insertUser(User user) { userDao.insertUser(user); } }
12.ACTION
package com.daizhaoyun.action; import java.util.ArrayList; import java.util.List; import com.daizhaoyun.dto.User; import com.daizhaoyun.service.UserService; import com.daizhaoyun.tools.ExcelOpt; import com.daizhaoyun.tools.GoToOracle; import com.opensymphony.xwork2.ActionSupport; @SuppressWarnings("serial") public class UserAction extends ActionSupport { private UserService userService; private List<User> list; private User user; public User getUser() { return user; } public void setUser(User user) { this.user = user; } public List<User> getList() { return list; } public void setList(List<User> list) { this.list = list; } public UserService getUserService() { return userService; } public void setUserService(UserService userService) { this.userService = userService; } /** * 系统入口 */ public String getAllUser(){ list = userService.getAllUser(); return SUCCESS; } /** * 数据导入Excel的操作 */ public String interExcel(){ //获取所有的表中数据 list = userService.getAllUser(); //EXCEL文件路径 String s = "D:/test.xls"; ExcelOpt eop = new ExcelOpt(); //数据导入Excel操作 eop.a(s, list); return SUCCESS; } /** * Excel导入到Oracle数据库表 */ public String goExcelToOracle(){ GoToOracle go = new GoToOracle(); String path="D:/test01.xls"; List<String> l = new ArrayList<String>(); l = go.insert(path); String[] st ; User user = new User(); for(int i=0;i<l.size();i++){ String str = l.get(i); st = str.split(","); user.setId(Integer.parseInt(st[0])); user.setUserName(st[1]); user.setPassword(st[2]); userService.insertUser(user); } return SUCCESS; } }
13.tools
package com.daizhaoyun.tools; import java.io.File; import java.io.IOException; import java.util.List; import com.daizhaoyun.dto.User; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; import jxl.write.WriteException; import jxl.write.biff.RowsExceededException; /** * @author daizhaoyun * 创建一个excel */ public class ExcelOpt{ /** * 生成一个Excel文件 jxl */ public void a(String fileName,List<User> list) { WritableWorkbook wwb = null; try { // 首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象 wwb = Workbook.createWorkbook(new File(fileName)); } catch (IOException e) { e.printStackTrace(); } if (wwb != null) { // 创建一个可写入的工作表 // Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置 WritableSheet ws = wwb.createSheet("用户信息表", 0); Label label1 = new Label(1, 0, "ID"); Label label2 = new Label(2, 0, "姓名"); Label label3 = new Label(3, 0, "密码"); try { // 下面开始添加单元格 ws.addCell(label1); ws.addCell(label2); ws.addCell(label3); } catch (RowsExceededException e1) { e1.printStackTrace(); } catch (WriteException e1) { e1.printStackTrace(); } // 下面开始添加单元格 for (int i = 0; i < list.size(); i++) { Label label4 = new Label(1, i+1,list.get(i).getId().toString()); Label label5 = new Label(2, i+1,list.get(i).getUserName()); Label label6 = new Label(3, i+1,list.get(i).getPassword()); // 这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行 /*Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第" + (j + 1) + "列");*/ try { // 将生成的单元格添加到工作表中 ws.addCell(label4); ws.addCell(label5); ws.addCell(label6); } catch (RowsExceededException e) { e.printStackTrace(); } catch (WriteException e) { e.printStackTrace(); } } try { // 从内存中写入文件中 wwb.write(); // 关闭资源,释放内存 wwb.close(); } catch (IOException e) { e.printStackTrace(); } catch (WriteException e) { e.printStackTrace(); } } } }
package com.daizhaoyun.tools; import java.io.File; import java.io.IOException; import java.util.ArrayList; import java.util.List; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import jxl.read.biff.BiffException; public class GoToOracle { public List<String> insert(String path) { List<String> list = new ArrayList<String>(); File file = new File(path); // 创建新的Excel 工作簿 Workbook rwb = null; try { rwb = Workbook.getWorkbook(file); } catch (BiffException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } // 得到工作簿中的第一个表索引即为excel下的sheet1,sheet2,sheet3... Sheet sheet = rwb.getSheets()[0]; int rsColumns = sheet.getColumns();// 列数 int rsRows = sheet.getRows();// 行数 String simNumber = "";// 每个单元格中的数据 String str = "";// 拼接要插入的列 for (int i = 1; i < rsRows; i++) { for (int j = 0; j < rsColumns; j++) { Cell cell = sheet.getCell(j, i); simNumber = cell.getContents(); if(j == rsColumns - 1){ str += simNumber; }else{ str += simNumber + ","; } } list.add(str); str = ""; } return list; } }
14.通过http://localhost:8080/excel/ getAllUser.action访问
- excel.rar (19.9 KB)
- 下载次数: 17
评论
2 楼
tiger112
2012-07-16
aixs3GKgn4oVplJGeAI96Q.. 这个竟然搜到你了 暴露了 哈哈哈
1 楼
tiger112
2012-07-16
你是一号店的 哈哈

相关推荐
DUN:Microsoft拔号网络导出文件 DV:数字视频文件(MIME) DWG:AutoCAD工程图文件;AutoCAD或Generic CADD老版本的绘图格式 DXR:Macromedia Director受保护(不可编辑)电影文件 E EDA:Ensoniq ASR磁盘映像...
内容概要:本文详细介绍了利用FLAC3D进行隧道台阶法施工模拟的方法和技术细节。首先解释了隧道台阶法施工的基本流程,重点在于开挖命令的应用,如'zone cmodel assign'和'zone remove'用于改变区域本构模型并执行开挖操作。接着阐述了支护结构的设置方法,包括超前加固体、初衬、二衬、锚杆和锁脚锚杆的具体配置方式。此外,还讲解了如何通过'mesh'命令直接在FLAC3D中生成符合实际工程需求的网格模型。最后展示了模拟后的围岩体位移云图和应力云图,验证了计算结果的有效性,强调了这些数据对优化施工方案的重要性。 适合人群:从事岩土工程、隧道工程及相关领域的工程师和技术人员。 使用场景及目标:适用于需要进行隧道施工模拟的专业人士,旨在提升他们对FLAC3D的理解和应用能力,确保隧道施工的安全性和高效性。 其他说明:文中提供的实例和命令操作均基于真实项目经验,有助于读者更好地理解和掌握FLAC3D的实际应用技巧。
内容概要:本文介绍了纤维骨料细观尺度混凝土模型的设计与应用,重点在于如何通过控制骨料尺寸和体积率,在不同有限元软件(如Abaqus、Ansys、Ls-Dyna、Flac3d)中进行有效的四面体网格划分和六面体网格投影。文中提供了生成随机骨料位置和直径的Python代码片段,并详细解释了网格划分过程中需要注意的技术细节,如碰撞检测、网格转换公式以及材料属性设置。此外,还讨论了模型验证的方法及其在实际工程项目中的应用价值。 适合人群:从事土木工程、材料科学领域的研究人员和技术人员,尤其是那些需要利用有限元方法进行混凝土结构分析的专业人士。 使用场景及目标:①帮助工程师更好地理解和预测纤维混凝土的行为特性;②为实际工程项目提供理论支持和技术指导,从而优化纤维混凝土的应用;③提高仿真精度,减少实验成本和时间。 其他说明:文中提到的一些具体操作步骤和技术细节对于初学者来说可能具有一定挑战性,建议读者在实践中逐步掌握相关技能并积累经验。同时,正确设置物理量单位非常重要,错误的单位可能导致计算结果严重偏离预期。
嵌入式八股文面试题库资料知识宝典-c++个人笔记总结.zip
内容概要:本文详细介绍了西门子S7-1200 PLC在工业自动化领域的应用,重点讲解了其模块、板卡和通讯方式。首先概述了PLC模块和板卡作为基本单元的作用,接着深入探讨了支持的多种通讯协议,包括Modbus-RTU、S7通讯、Modbus-TCP和TCP/IP等。每种协议都配有具体的代码分析和调试方法。最后,介绍了博途V16编程软件的使用体验,强调了其对S7-1200 PLC编程的支持。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对西门子S7-1200 PLC有初步了解或希望深入了解的人群。 使用场景及目标:适用于需要掌握PLC模块化设计、不同通讯协议的应用场景,旨在帮助读者理解PLC的工作原理,提高编程和调试能力,从而更好地应用于实际项目中。 其他说明:文中提供的实例和代码分析有助于读者快速上手,同时推荐使用博途V16及以上版本的编程软件进行实践操作。
内容概要:本文介绍了Comsol仿真软件在等离子体空气反应领域的应用,重点探讨了其无模型反应框架的功能。该框架能模拟超过40种气体(如氧气、氮气、氦气)的详细反应过程,提供碰撞截面数据、迁移率扩散系数、速率系数和汤森系数的查询与求解功能,并通过bosig+模块实现自定义反应路径的选择。此外,文中强调了代码分析与实践应用的重要性,以及这些功能如何提升等离子体反应研究的效率和准确性。 适合人群:从事等离子体物理、化学反应动力学及相关领域研究的专业人士和技术人员。 使用场景及目标:适用于需要精确模拟复杂等离子体环境中气体反应的研究项目,旨在提高对等离子体反应机制的理解,优化实验设计,预测反应行为。 其他说明:Comsol仿真软件凭借其强大的计算能力,在等离子体研究中扮演着重要角色。随着技术的发展,该框架有望进一步推动相关领域的创新和发展。
嵌入式八股文面试题库资料知识宝典-同方万维硬件测试工程师.zip
嵌入式八股文面试题库资料知识宝典-c,c++笔试.zip
少儿编程scratch项目源代码文件案例素材-激光连接.zip
嵌入式八股文面试题库资料知识宝典-奔图电子-软件笔试试题v1.1(C,C++工程师).zip
嵌入式八股文面试题库资料知识宝典-国科环宇有限公司.zip
基于LDA主题模型对AIGC的影响力分析.pdf
可以自己添加应用和功能版,在/opt/upt/apps/下面添加ubin目录和ulib目录,把你想用的程序添加到ubin,支持模块添加到ulib中,就可以运行,具体刷机操作,请看《》
内容概要:本文探讨了遗传算法在车辆路径优化问题(VRP)中的应用及其改进,特别是在冷链物流、软时间窗和多配送中心场景下的路径优化策略。文中介绍了遗传算法通过模拟自然界进化过程来寻找最优路径解决方案的能力,并详细讨论了其在冷链物流中的重要性,即确保产品运输过程中的温度稳定和时效性。此外,还提到了软时间窗概念的应用,以平衡客户满意度和运输成本。在多配送中心场景下,遗传算法能有效处理复杂路径规划问题,如外卖配送路径优化和充电桩电车车辆路径优化。除了遗传算法,蚁群算法、模拟退火算法和粒子群算法也在不同类型的路径优化问题上得到广泛应用,如旅行商问题(TSP)、容量约束的车辆路径规划(CVRP)和带距离、容量和时间窗约束的车辆路径规划(VRPTW)。最后,文章强调了遗传算法改进的研究方向,旨在提高运算速度和精度,从而提升物流效率和客户满意度。 适合人群:从事物流与运输领域的研究人员和技术人员,对车辆路径优化感兴趣的学者和从业者。 使用场景及目标:适用于冷链物流、外卖配送、充电桩电车等多种实际应用场景,旨在优化路径规划,降低运输成本,提高客户满意度。 其他说明:本文不仅介绍了现有算法的应用情况,还指出了未来可能的研究方向和发展趋势。
内容概要:本文详细介绍了物流领域的车辆路径优化(VRP)及其扩展问题——带时间窗的车辆路径优化(VRPTW),并探讨了冷链物流车辆路径优化(考虑充电桩需求)。文中通过MATLAB实现了遗传算法解决这些问题的具体步骤,包括参数设置、种群初始化、适应度函数计算、遗传算法循环等。此外,还讨论了多配送中心场景下的路径优化挑战和其他优化算法(如蚁群算法、粒子群算法、节约算法和模拟退火算法)的应用。最后,针对冷链物流和电动汽车路径优化提出了具体的解决方案和技术细节。 适合人群:从事物流管理、运筹学、算法设计的研究人员和工程师,尤其是对MATLAB有一定基础的技术人员。 使用场景及目标:适用于需要优化物流配送路径的企业和个人,旨在提高配送效率、降低成本、提升服务质量。具体应用场景包括但不限于城市配送、冷链运输、电动车辆调度等。 其他说明:文中提供了完整的MATLAB代码示例,帮助读者更好地理解和实践各种优化算法。同时,强调了不同算法的特点和适用条件,便于读者根据实际情况选择最合适的算法。
嵌入式八股文面试题库资料知识宝典-文思创新面试题2.zip
嵌入式八股文面试题库资料知识宝典-网络编程.zip
少儿编程scratch项目源代码文件案例素材-火柴人防御.zip
AI数字形象制作口播视频