Java利用response对象导出table表格的数据

试了一下,可以把数据输出成一个excel表格,原理是什么?

 <%@ page contentType="application/vnd.ms-excel;charset=GBK" %>  
<%@page import="java.net.URLEncoder"%>  

<%  
String filedisplay = "文件.xls";   
filedisplay = URLEncoder.encode(filedisplay, "UTF-8");   
response.addHeader("Content-Disposition", "attachment;filename="   + filedisplay);   
%>  
<!doctype html>  

<html>  
    <head>  
        <title>导出Excel实例</title>  
        <style>tr td{border:1px black solid;}</style>  
    </head>  
    <body>  
        <table style="border:1px">  
            <tr>  
                <td>ID</td>  
                <td>名称</td>  
                <td>性别</td>  
                <td>年龄</td>  
            </tr>  
            <tr>  
                <td>1</td>  
                <td>张三</td>  
                <td>男</td>  
                <td>18</td>  
            </tr>  
            <tr>  
                <td>2</td>  
                <td>张三</td>  
                <td>男</td>  
                <td>18</td>  
            </tr><tr>  
                <td>3</td>  
                <td>张三</td>  
                <td>男</td>  
                <td>18</td>  
            </tr><tr>  
                <td>4</td>  
                <td>张三</td>  
                <td>男</td>  
                <td>18</td>  
            </tr>  
        </table>  
    </body>  
</html>  

1个回答

输出的根本不是 excel 格式(虽然掩耳盗铃地用了xls后缀)而是 html。但是excel本身可以识别和读取html,甚至文本文件等。给你的假象是,导出的是 excel 文件。

u013179958
CSDNRGY 感觉掩耳盗铃在这里用语法上说不过去
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java中的context对象、request对象、response对象都可以存放什么数据?

java中的context对象、request对象、response对象在向应用服务器发送请求的过程中都会用到,分别可以存放哪些数据呢?求大神解答,不胜感激!

有关导出excel表格的问题,代码如下,导出的excel表格里面没有数据,list集合不为空。

``` @RequestMapping("export") public void export(BuchangAnzhiViewRequest req, HttpServletResponse response) throws IOException, InstantiationException, IllegalAccessException { List<BuchangAnzhiView> viewList = getBuchangAnzhiViews(req, req.getPage()); Workbook wb = getWorkbook("/template/buchanganzhi.mingxi.export.xlsx"); Sheet sheet = wb.getSheetAt(0); if(CollectionUtils.isNotEmpty(viewList)){ for(int i=0; i < viewList.size(); i++){ Row row = sheet.createRow(i+2); BuchangAnzhiView view = viewList.get(i); int column = 0; setCell(row, column++, view.getBatchNo()); setCell(row, column++, view.getRelocateNo()); setCell(row, column++, view.getRelocateName()); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getHouseMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getDecorationMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getAttachmentMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getMoveMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getTransitionCost())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getAgreementAward())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getSubmitAward())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getOtherCompensate())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getTotalCompensate())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getBuildingPrice())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getFloorBalance())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getSettlementPrice())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getGaragePrice())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getGarageMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getTotalHouseMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getMaintainMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getSettlementBalance())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getOtherMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getTotalMoney())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getTemporaryDeposit())); setCell(row, column++, wb, MoneyUtils.formatBigDecimalMoney2String(view.getTotalGetMoney())); } } response.setContentType("application/vnd.ms-excel"); response.setHeader("Content-Disposition", "attachment; filename=" + encodeFileName("拆迁项目补偿安置情况明细查询表-" + CzyszjUtil.getCurrentYYYYMMDD() +".xlsx")); ServletOutputStream out = response.getOutputStream(); wb.write(out); out.flush(); } ```

用java做一个导出ppt格式

怎么实现导出ppt格式的文件;

java poi 分组查询导出Excel怎么实现

有个用户表(t_user) 有一个 用户订单记录表(dngdan) 其中有主外键关联,我想导出这种样式 用户姓名 订单号 张三 1 2 3.... 李四 1 2 3 这样的格式 怎么导出啊

将jsp页面中表格中数据导出到Excel文件中出现了错误

java.lang.IllegalStateException: Cannot call sendError() after the response has been committed at org.apache.catalina.connector.ResponseFacade.sendError(ResponseFacade.java:450) at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:771) at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:506) at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77) at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:423) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1079) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:620) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2476) at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2465) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:744)

java批量数据导出多个excel,为什么老是只生成一个excel文件

public void exportexcel(HttpServletRequest request, HttpServletResponse response) throws Exception { // 为模板中变量赋值 // 传递模板地址和要操作的页签 ExcelExp excel = new XssExcelExp("../../excel/volunteer.xlsx", 0); VolunteerFormMap volunteerFormMap = findHasHMap(VolunteerFormMap.class); volunteerFormMap.put("mapper_id","VolunteerMapper.findvolunteer"); List<Map<String, Object>> lists = baseService.findByAll(volunteerFormMap); for (Map<String, Object> map2 : lists) { Map<String, String> map1 = new HashMap<String, String>(); map1.put("name", (String) map2.get("name")); map1.put("gender", (String) map2.get("gender")); map1.put("education", (String) map2.get("education")); map1.put("politicalAff", (String) map2.get("political_aff")); map1.put("workUnit", (String) map2.get("work_unit")); map1.put("unitAddress", (String) map2.get("unit_address")); map1.put("address", (String) map2.get("address")); map1.put("phoneNumber", (String) map2.get("phoneNumber")); map1.put("idNumber", (String) map2.get("id_number")); map1.put("hobby", (String) map2.get("hobby")); map1.put("contactInfo", (String) map2.get("contact_info")); map1.put("introducer", (String) map2.get("introducer")); map1.put("partinTime", (String) map2.get("partin_time")); excel.replaceExcelData(map1); // 导出,此处只封装了浏览器下载方式 // 调用downloadExcel,返回输出流给客户端 String fileName = (String) map2.get("name") + ".xlsx"; excel.downloadExcel(response, fileName); } } public void downloadExcel(HttpServletResponse response, String filaName) throws IOException { String encodeFileName = URLEncoder.encode(filaName, "UTF-8"); response.addHeader("Content-Disposition", "attachment;filename=" + encodeFileName); //response.setHeader("Accept-Ranges", "bytes"); ServletOutputStream out = response.getOutputStream(); xssWb.write(out); out.flush(); out.close(); }

java 如何一次 导出多个文件

java 如何一次导出多个 excel 或者 pdf 文件?

急急急,java导出excel没反应

``` @ResponseBody @RequestMapping("downDataList") public boolean downDataList(HttpServletRequest request, HttpServletResponse response, PageUtil pageUtil, MyTStoreVO myStoreVO, MyTSkuVO mySkuVO) { List<TSku> sku = skuBO.find(mySkuVO); if (sku.size() != 0) { String[] skunoIn = new String[sku.size()]; for (int i = 0; i < sku.size(); i++) { skunoIn[i] = sku.get(i).getSkuno(); } myStoreVO.setSkunoIn(skunoIn); List<TStore> list = storeBO.find(myStoreVO, pageUtil.getRows(), pageUtil.getPage()); for (TStore u : list) { for (TSku c : sku) { if (u.getSkuno() != null && u.getSkuno() != "" && u.getSkuno().equals(c.getSkuno())) { u.setSkuno(c.getSkuname()); } } if (Integer.parseInt(u.getCount()) <= 20) { u.setCountWarning("库存不足"); } } final Collator collator = Collator.getInstance(Locale.CHINA); Collections.sort(list, new Comparator<TStore>() { @Override public int compare(TStore o1, TStore o2) { return collator.compare(o1.getSkuno(), o2.getSkuno()); } }); for (TStore u : list) { System.out.println(u.toString()); } // 创建HSSFWorkbook对象(excel的文档对象) HSSFWorkbook wkb = new HSSFWorkbook(); // 建立新的sheet对象(excel的表单) HSSFSheet sheet = wkb.createSheet("库存情况"); // 在sheet里创建第一行,参数为行索引(excel的行),可以是0~65535之间的任何一个 HSSFRow row1 = sheet.createRow(0); // 创建单元格(excel的单元格,参数为列索引,可以是0~255之间的任何一个 HSSFCell cell = row1.createCell(0); // 设置单元格内容 cell.setCellValue("库存情况表" + MyDateUtil.getCurrentDate2()); // 合并单元格CellRangeAddress构造参数依次表示起始行,截至行,起始列, 截至列 sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 5)); HSSFRow row2 = sheet.createRow(1); // 创建单元格并设置单元格内容 row2.createCell(0).setCellValue("SKU名称"); row2.createCell(1).setCellValue("入库数量"); row2.createCell(2).setCellValue("出库数量"); row2.createCell(3).setCellValue("库存量"); row2.createCell(4).setCellValue("库存状态"); row2.createCell(5).setCellValue("在售数量"); int i = 0; for (TStore u : list) { HSSFRow row = sheet.createRow(i + 2); row.createCell(0).setCellValue(u.getSkuno()); row.createCell(1).setCellValue(u.getIncnt()); row.createCell(2).setCellValue(u.getOutcnt()); row.createCell(3).setCellValue(u.getCount()); row.createCell(4).setCellValue(u.getCountWarning()); row.createCell(5).setCellValue(u.getSalescnt()); i++; } // 输出Excel文件 try { OutputStream output = response.getOutputStream(); response.reset(); response.setHeader("Content-disposition", "attachment; filename=库存情况表"+ MyDateUtil.getCurrentDate2()+".xls"); response.setContentType("application/msexcel"); wkb.write(output); output.close(); } catch (IOException e) { e.printStackTrace(); } return true; } else return false; } ``` 设断点看了,全部执行,但是就是没下载表格的反应

java中获取HashMap中的table?

我的目标是想遍历table,打印真实在HashMap中table的数据结构,目前可以通过反射得到table,但是table中的元素是HashMap.Entry,是一个静态内部类,无法将其造型成HashMap.Entry类型,求助中 Field field=HashMap.class.getDeclaredField("table"); field.setAccessible(true); //设置些属性是可以访问的 Object obj=field.get(lzc2map); System.out.println(obj);

导出 大量数据内存溢出,

在 本机上用eclipse导出一百多万的数据导出,没有问题,但是部署在应用服务器上就会内存溢出,而且我把本机的tomcat也拷贝过去了。其它一个功能,比这数据还多几W,只不过少写出了几个字段,也能正常导出。 int totalSize = behaviorPortraitService.querySiletUserPortraitCountMonth(sietUserPortraitForm.getParams()); int pageNum = 0; if (totalSize % 1000000 == 0) { pageNum = totalSize / 1000000; }else{ pageNum = totalSize / 1000000 + 1; } write.append(" 年/月 IMSI 手机号码 沉默天数 开卡时间" + enter); outSTr = response.getOutputStream(); // 建立 buff = new BufferedOutputStream(outSTr); // 循环总页数,得到每页的页数 for (int i = 1; i <= pageNum; i++) { // 根据页数,得到 PageResult对象 list = behaviorPortraitService.exportSiletUserPortraitMonth(sietUserPortraitForm.getParams(),i,100000); // 循环List集合进行写入 for (int j = 0; j < list.size(); j++) { // 循环集合,写入数据到TXT中 write.append(list.get(j).getBegin_endtime()); write.append(" " + list.get(j).getImsi()); write.append(" " + list.get(j).getMsisdn()); write.append(" "+ list.get(j).getSilencedays()); write.append(" " + list.get(j).getStarttime() + enter); } // 写完一个分页对象之后,清空List,清楚缓存 list.clear(); System.gc(); } buff.write(write.toString().getBytes("UTF-8")); 错误信息: org.springframework.web.util.NestedServletException: Handler processing failed; nested exception is java.lang.OutOfMemoryError: Java heap space org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:839) org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719) org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644) org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:549) javax.servlet.http.HttpServlet.service(HttpServlet.java:617) javax.servlet.http.HttpServlet.service(HttpServlet.java:717) com.trajectory.manager.controller.filter.SessionPrivaligeFilter.doFilter(SessionPrivaligeFilter.java:79) org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) root cause java.lang.OutOfMemoryError: Java heap space java.lang.StringCoding$StringEncoder.encode(StringCoding.java:232) java.lang.StringCoding.encode(StringCoding.java:272) java.lang.String.getBytes(String.java:946) com.trajectory.behaviorportrait.controller.ExportSiletUserPortraitController.writeWeekTxtWeek(ExportSiletUserPortraitController.java:209) com.trajectory.behaviorportrait.controller.ExportSiletUserPortraitController.handleRequestInternal(ExportSiletUserPortraitController.java:69) org.springframework.web.servlet.mvc.AbstractController.handleRequest(AbstractController.java:153) org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter.handle(SimpleControllerHandlerAdapter.java:48) org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:790) org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719) org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644) org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:549) javax.servlet.http.HttpServlet.service(HttpServlet.java:617) javax.servlet.http.HttpServlet.service(HttpServlet.java:717) com.trajectory.manager.controller.filter.SessionPrivaligeFilter.doFilter(SessionPrivaligeFilter.java:79) org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)

为什么java导出excel表格没有弹出下载框

/** 导出存支列表 */ public void exportDepositList(){ HttpServletResponse response = Struts2Utils.getResponse(); ServletOutputStream sos = null; WritableWorkbook wb = null; List<DepositEntity> depositList = null; String str = getSql(); depositList = depositService.getDepositForList(str, -1, -1); String fileName = depositList.get(0).getDeptName()+"-存支列表.xls"; try { if(deposit == null){return;} float zsr = 0;float zzc = 0; sos = response.getOutputStream(); response.reset(); response.setContentType("application/octet-stream"); response.setHeader("Content-disposition", "attachment;fileName=" + URLEncoder.encode(fileName, "UTF-8")); wb = Workbook.createWorkbook(sos); WritableSheet ws = wb.createSheet("存支列表",0); WritableCellFormat wcfTitle = new WritableCellFormat(); wcfTitle.setBackground(Colour.GRAY_25); ws.setRowView(0, 600, false); //设置行高 ws.setColumnView(0, 20); ws.setColumnView(1, 20); ws.setColumnView(2, 20); ws.setColumnView(3, 6); ws.setColumnView(6, 13); ws.setColumnView(8, 15); ws.setColumnView(10, 15); ws.setColumnView(12, 13); ws.setColumnView(13, 13); ws.addCell(new Label(0, 0, "类型", wcfTitle)); ws.addCell(new Label(1, 0, "收入", wcfTitle)); ws.addCell(new Label(2, 0, "支出", wcfTitle)); ws.addCell(new Label(3, 0, "余额", wcfTitle)); ws.addCell(new Label(4, 0, "存付单位名称", wcfTitle)); ws.addCell(new Label(5, 0, "存支时间", wcfTitle)); ws.addCell(new Label(6, 0, "订单号", wcfTitle)); ws.addCell(new Label(7, 0, "备注", wcfTitle)); ws.addCell(new Label(8, 0, "入账", wcfTitle)); ws.addCell(new Label(9, 0, "核算号", wcfTitle)); ws.addCell(new Label(10, 0, "核定", wcfTitle)); ws.addCell(new Label(11, 0, "收款已用", wcfTitle)); ws.addCell(new Label(12, 0, "编号", wcfTitle)); int toursCount = 1; for (DepositEntity deposit : depositList) { ws.addCell(new Label(0, toursCount, deposit.getDepoType())); if(deposit.getMtype() == 1){ ws.addCell(new Label(1, toursCount, String.valueOf(deposit.getMoney()))); zsr += deposit.getMoney(); }else if(deposit.getMtype() == 0){ ws.addCell(new Label(2, toursCount, String.valueOf(deposit.getMoney()))); zzc += deposit.getMoney(); } ws.addCell(new Label(3, toursCount, String.valueOf(deposit.getEmoney()))); ws.addCell(new Label(4, toursCount, deposit.getCustomer())); ws.addCell(new Label(5, toursCount, deposit.getAddTime())); ws.addCell(new Label(6, toursCount, deposit.getOrderNum())); ws.addCell(new Label(7, toursCount, deposit.getRemark())); if(deposit.getIsAccounte() == 0){ws.addCell(new Label(8, toursCount, ""));}else{ws.addCell(new Label(8, toursCount, "√"));} ws.addCell(new Label(9, toursCount, deposit.getCheckBatchNum())); ws.addCell(new Label(10, toursCount, String.valueOf(deposit.getHmoney()))); ws.addCell(new Label(11, toursCount, String.valueOf(deposit.getYmoney()))); ws.addCell(new Label(12, toursCount, deposit.getDepoNum())); toursCount++; } ws.addCell(new Label(2, toursCount+5, "统计")); ws.addCell(new Label(4, toursCount+5, "总收入:"+String.valueOf(zsr))); ws.addCell(new Label(6, toursCount+5, "总支出:"+String.valueOf(zzc))); ws.addCell(new Label(8, toursCount+5, "余额:"+String.valueOf(zsr-zzc))); } catch (Exception e) { e.printStackTrace(); } finally { if(wb != null){ try { wb.write(); wb.close(); } catch (Exception e) { e.printStackTrace(); } } if(sos != null){ try { sos.flush(); sos.close(); } catch (Exception e) { e.printStackTrace(); } } } }

Java如何获得response内容

我想在过滤器执行完chain.doFilter(request, response)时,获得得response内容

springboot项目实现导出excel表格,调用方法报错

![图片说明](https://img-ask.csdn.net/upload/201703/09/1489069717_486971.png)![![图片说明](https://img-ask.csdn.net/upload/201703/09/1489069778_447572.png)图片说明](https://img-ask.csdn.net/upload/201703/09/1489069766_587363.png)

使用POI导出word文档时,将数据写入输出流报错

**org.apache.poi.openxml4j.exceptions.OpenXML4JRuntimeException: Fail to save: an error occurs while saving the package : class org.apache.poi.openxml4j.util.ZipSecureFile$ThresholdInputStream cannot be cast to class java.util.zip.ZipFile$ZipFileInputStream (org.apache.poi.openxml4j.util.ZipSecureFile$ThresholdInputStream is in unnamed module of loader 'app'; java.util.zip.ZipFile$ZipFileInputStream is in module java.base of loader 'bootstrap')** ``` at org.apache.poi.openxml4j.opc.ZipPackage.saveImpl(ZipPackage.java:595) at org.apache.poi.openxml4j.opc.OPCPackage.save(OPCPackage.java:1539) at org.apache.poi.POIXMLDocument.write(POIXMLDocument.java:227) at com.xinpengtech.operation.co.order.base.service.WordUtil.exportWord(WordUtil.java:38) at com.xinpengtech.operation.co.order.base.service.CoOrderService.export(CoOrderService.java:778) at com.xinpengtech.operation.co.order.base.service.CoOrderService$$FastClassBySpringCGLIB$$977f0048.invoke(<generated>) at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:685) at com.xinpengtech.operation.co.order.base.service.CoOrderService$$EnhancerBySpringCGLIB$$f95e785a.export(<generated>) at com.xinpengtech.operation.co.order.base.view.TranscriptController.export(TranscriptController.java:37) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.base/java.lang.reflect.Method.invoke(Method.java:566) at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:190) at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:138) at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:106) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:888) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:793) at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1040) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943) ...... ``` 我现在做的项目要用到导出文件的功能,然后就去学了Apache POI通过模板文件生成word文档的功能。 我写的demo在main方法和web接口下都能正常生成生成word文档;但是一移植到公司的项目上就报错了,controller和service层的业务逻辑是没问题的,调用到poi的api时才开始报错。我觉得和项目之间jar包依赖有关,因为系统刚拆了微服务,也不知道是不是这个原因,求解 ``` /** * 根据模板生成word文档 * @param inputUrl 模板路径 * @param textMap 要替换的参数 * @param tableList 表格参数 */ public static void exportWord(String inputUrl, String fileName, Map<String, String> textMap, List<String[]> tableList, HttpServletResponse response){ try{ // 获取docx解析对象 XWPFDocument document = new XWPFDocument(POIXMLDocument.openPackage(inputUrl)); // 解析替换文本段落对象 changeText(document, textMap); // 解析替换表格对象 changeTable(document, textMap, tableList); // 导出到response输出流中 ServletOutputStream os = response.getOutputStream(); response.setHeader("Content-disposition", "attachment;fileName=" + fileName); document.write(os); // 这里报错 os.close(); }catch(Exception e){ e.printStackTrace(); } } ```

java poi 导出excel 把一样的数据动态合并单元格

急求,有一个list<map>数据 导出成![图片说明](https://img-ask.csdn.net/upload/201504/24/1429882933_758139.png) 这种格式 公司和年份两列是要有动态合并功能 并且年份合并的时候不能跨公司 有没有大神帮帮忙... ``` HSSFWorkbook workbook = new HSSFWorkbook(); String[] columnNames = new String[]{"编号","公司", "年份","性质", "名称","议案审核","召开时间","我方董监事","开展情况","决议"}; String[] columnKey = new String[]{"BIANHAO", "SGLWDW" ,"SGND","SGHYXZ","TITLENAME","BILLAUDIT","SGZKSJ","SGWFDS","DEVELOPMENT","DECISION"}; Map resMap = new HashMap(); try { if(list.size()==0){ resMap=new HashMap<String, String>(); resMap.put("tsBy1", "没有数据"); list.add(resMap); } HSSFSheet sheet = workbook.createSheet("sheet"+1); //首先,我们读取list中的第一个元素,根据它来确定工作表的列名,以及输出数据所对应的方法数组 Map<String,String> map2 = list.get(0); HSSFRow row = sheet.createRow(0); //创建第1行,也就是输出表头 HSSFCell cell; for(int i=0;i<columnNames.length;i++){ cell = row.createCell(i); //创建第i列 cell.setCellValue(new HSSFRichTextString(columnNames[i])); } //下面是输出各行的数据 for (int i = 0; i < list.size(); i++) { map2=(Map<String,String>)list.get(i); row=sheet.createRow(i+1);//创建第i+1行 for ( int j = 0; j < columnKey.length; j ++){ cell = row.createCell(j);//创建第j列 if(columnKey[j]==null || "".equals(columnKey[j])){ cell.setCellValue(i+1); }else{ Object obj = map2.get(columnKey[j]); cell.setCellValue(obj==null?"":obj.toString()); } } } row=sheet.createRow((short)(sheet.getLastRowNum()+1)); //在现有行号后追加数据 Region range = new Region(sheet.getLastRowNum(), (short)0, sheet.getLastRowNum(), (short)9); sheet.addMergedRegion(range); row.createCell(0).setCellValue(convoke+"家企业“已召开”,"+submit+"家企业议案“已提交”,"+archive+"家企业决议“已归档”,"+audit+"家企业议案“已审核”"); //设置第一个(从0开始)单元格的数据 OutputStream out = null; HttpServletResponse response = this.getResponse(); response.setContentType("octets/stream"); response.addHeader("Content-Disposition", "attachment;filename=_directorsDetail.xls"); try { out = response.getOutputStream(); workbook.write(out); out.close(); } catch (IOException e) { e.printStackTrace(); } ```

利用response对象的sendRedirect方法跳转到下一页面,能保存什么范围的属性?

利用response对象的sendRedirect方法跳转到下一页面,能保存什么范围的属性?本人新手,知识面还是很多,请大神们帮我解答一下!

前端js实现web页面导出Excel,乱码问题

### 以下是我用的js: ### 使用以下代码导出的Excel文件在WPS中打开好像是正常的,但是在office中打开时,会出现以下提示(我用的是office 2013版的): ![图片说明](https://img-ask.csdn.net/upload/201712/25/1514186548_925715.png) ### 而且有的时候是乱码的(office 2010版本的出现过乱码的),而有的时候又是正常显示的,具体有什么规律在里面我不清楚。怎么解决这个问题,希望得到你们的帮助。挺急的! ``` var idTmr; function getExplorer() { var explorer = window.navigator.userAgent ; //ie if (explorer.indexOf("MSIE") >= 0) { return 'ie'; } //firefox else if (explorer.indexOf("Firefox") >= 0) { return 'Firefox'; } //Chrome else if(explorer.indexOf("Chrome") >= 0){ return 'Chrome'; } //Opera else if(explorer.indexOf("Opera") >= 0){ return 'Opera'; } //Safari else if(explorer.indexOf("Safari") >= 0){ return 'Safari'; } } function Cleanup() { window.clearInterval(idTmr); CollectGarbage(); } var tableToExcel = (function() { var uri = 'data:application/vnd.ms-excel;base64,', template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>', base64 = function(s) { return window.btoa(unescape(encodeURIComponent(s))) }, format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) } return function(table, name) { if (!table.nodeType) table = document.getElementById(table); var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML} window.location.href = uri + base64(format(template, ctx)) } })(); export function method1(tableid){ //整个表格拷贝到EXCEL中 if(getExplorer()=='ie') { var curTbl = document.getElementById(tableid); var oXL = new ActiveXObject("Excel.Application"); //创建AX对象excel var oWB = oXL.Workbooks.Add(); //获取workbook对象 var xlsheet = oWB.Worksheets(1); //激活当前sheet var sel = document.body.createTextRange(); sel.moveToElementText(curTbl); //把表格中的内容移到TextRange中 sel.select; //全选TextRange中内容 sel.execCommand("Copy"); //复制TextRange中内容 xlsheet.Paste(); //粘贴到活动的EXCEL中 oXL.Visible = true; //设置excel可见属性 try { var fname = oXL.Application.GetSaveAsFilename("Excel.xls", "Excel Spreadsheets (*.xls), *.xls"); } catch (e) { print("Nested catch caught " + e); } finally { oWB.SaveAs(fname); oWB.Close(savechanges = false); //xls.visible = false; oXL.Quit(); oXL = null; //结束excel进程,退出完成 //window.setInterval("Cleanup();",1); idTmr = window.setInterval("Cleanup();", 1); } }else{tableToExcel(tableid)} }; ```

java使用poi实现excel导出之后如何弹出保存提示框

无论使用poi还是使用jxl导出excel都需要用到流 一种是outputstrean,另一种fileoutputstream 第一种:如果想要弹出保存的提示框必须加入下列三句 response.setContentType("application/vnd.ms-excel; charset=utf-8"); response.setHeader("Content-Disposition","attachment;filename="+filename); response.setCharacterEncoding("utf-8"); OutputStream os=response.getOutputStream(); 在使用第一种的时候,我用的ajax请求。导致excel无法导出,最后我直接请求可以导出 原因是:ajax也用到了response.getWriter()方法 要将 数据结果回传,这里 我虽然 放弃了 回传的写入流writer 参数, 但是ajax还是会默认的去掉用,把流已经占用了,当然返回不了任何东西了。 第二种: action中使用 FileOutputStream fos=new FileOutputStream(file); 此时可以使用ajax请求,在导出成功后返回文件路径,在页面中使用window.open(path);即可打开导出的excel文件

C# html表格导出成Excel问题

![图片说明](https://img-ask.csdn.net/upload/201607/27/1469612357_74672.jpg) 本地导出Excel 正常,但是部署到到服务器后,html格式全部消失,只剩下数据,如下图: ![图片说明](https://img-ask.csdn.net/upload/201607/27/1469612401_209389.png)

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

navicat(内含激活码)

navicat支持mysql的可视化操作,内涵激活码,不用再忍受弹框的痛苦。

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

基于STM32的电子时钟设计

时钟功能 还有闹钟功能,温湿度功能,整点报时功能 你值得拥有

学生成绩管理系统(PHP + MYSQL)

做的是数据库课程设计,使用的php + MySQL,本来是黄金搭配也就没啥说的,推荐使用wamp服务器,里面有详细的使用说明,带有界面的啊!呵呵 不行的话,可以给我留言!

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

多功能数字钟.zip

利用数字电子计数知识设计并制作的数字电子钟(含multisim仿真),该数字钟具有显示星期、24小时制时间、闹铃、整点报时、时间校准功能

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

几率大的Redis面试题(含答案)

本文的面试题如下: Redis 持久化机制 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题 热点数据和冷数据是什么 Memcache与Redis的区别都有哪些? 单线程的redis为什么这么快 redis的数据类型,以及每种数据类型的使用场景,Redis 内部结构 redis的过期策略以及内存淘汰机制【~】 Redis 为什么是单线程的,优点 如何解决redis的并发竞争key问题 Red...

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

u-boot-2015.07.tar.bz2

uboot-2015-07最新代码,喜欢的朋友请拿去

相关热词 c# 局部 截图 页面 c#实现简单的文件管理器 c# where c# 取文件夹路径 c# 对比 当天 c# fir 滤波器 c# 和站 队列 c# txt 去空格 c#移除其他类事件 c# 自动截屏
立即提问