不过,在此之前,本人就算是在Excel中操作都不会设置下拉,跟别说级联下拉了,并且关于使用代码生成级联下拉这块,网上并没有相关的可以值得借鉴的内容,但是无论如何,Excel小白还是要挑战挑战的。...这个有效性菜单你会发现在高版本无法找到,我找了半天,终于找到了: ? 就是这个图标!!!现在叫"数据验证"!!! 通过以上教程,我们可以学会配置了Excel级联列表: 数据源如下: ?...搞定了Excel,我们学到了以下几个概念: 通过名称管理器,我们可以定义序列,或者叫列表和数据源吧 通过数据验证,我们可以设置当单元格所绑定的序列 ?...通过INDIRECT函数,我们可以实现下拉级联效果: ? 其实这个级联的实现的思路很有意思,通过INDIRECT获取到关联单元格的值,然后这个值就是关联列表的序列名称。...现在我来说说思路(思路是高于开发的,很多时候如果做一个东西没有思路,那就很容易"作死",在开发过程中要有意识的培养自己的思路,一方面是思路的形成可以在很多场景迁移借鉴,另一方面是既保障灵活性、扩展性和严谨性的前提下
使用Excel录入数据的时候我们通常使用下拉列表来限定输入的数据,这样录入数据就很少发生错误了。Excel 2013较以前的版本发生了很大的变化,那么在Excel 2013是如何添加下拉列表的呢?...下面Office办公助手的小编就以“性别”中下拉选择男女为例,讲解下Excel 2013中添加下拉列表的方法。更复杂的大家可以举一反三,方法是一样的。 1、首先要选中你要添加下拉列表的单元格。...2、在菜单栏上选择数据--数据验证--数据验证。 3、打开如图所示的对话框,切换到设置选项下。 4、将允许条件设置为序列,如图所示,并勾选后面的两个选项。...6、到这里,这个单元格已经设置完毕,我们可以使用快速填充来对整列进行填充。 7、拖动单元格的右下角,向下拖动即可完成快速填充。 8、我们看到这列单元格都具有了下拉列表。
本文做最简单的引入——处理和使用POI数据,也是结合之前的推文:POI数据获取脚本分享,希望这里分享的脚本有更大的受众。...---- -2nd- 操作 01 基础 I 一份带有地理空间信息的表格数据.xlsx (测试xls格式、xlsx[兼容模式] 无法使用三维地图功能,xls需另存为xlsx,xlsx[兼容模式...I 坐标问题 理论上地图在无法使用通用的WGS84坐标系(规定吧),同一份数据对比ArcGIS中的WGS84(4326)和Excel中的WGS84、CJ-02(火星坐标系)的显示效果,可能WGS84(...操作:在主工作界面右键——更改地图类型——新建自定义底图——浏览背景图片——调整底图——完成 i 底图校准 加载底图图片后,Excel会使用最佳的数据-底图配准方案——就是让所有数据都落位在底图上。...⇩ 不同分辨率下的图片尺寸 更简便的方法是,按住Alt+双击图片——打开图片属性面板——详细信息——下拉查看图片尺寸 III 导出 使用导出选项卡,[捕捉屏幕]类似截屏,保存在剪切板,需要打开其他软件复制粘贴后再另存到本地
Excel相关知识点 (1)名称管理器——Name Manager 【CoderBaby】首先需要创建多个名称(包含key及value),作为下拉列表的数据源,供后续通过名称引用。...areaNames); } } return subAreas; } 注:必须用LinkedHashMap,否则初始化数据会重新排序,导致后续生成下拉列表的层级关系出错...rowNum) { return "INDIRECT($" + offset + (rowNum) + ")"; } 最终实现效果 名称管理器的数据源工作表: 名称管理器: 生成的模板...: 附: 1) Excel 多级联动下拉列表: https://blog.csdn.net/zhan107876/article/details/95341684 本文版权归作者和博客园共有,欢迎转载,...但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如下图1所示,在工作表Sheet1的列A中任意单元格上双击鼠标,将会出现一个窗体控件,单击其右侧的下拉箭头会出现列表,你可以从中选择列表项,所选项将被输入到该控件所在的单元格中,并且输入数据后该控件会消失...定义下拉列表的OnAction属性为EnterInfo过程,这表明当从下拉列表中选择一个列表项时将运行EnterInfo过程。 2....EnterInfo过程使用Application.Caller返回调用OnAction设定过程的下拉控件的名称,从而获取对该控件对象的引用。...3.DropDown对象的TopLeftCell属性返回位于该对象左上角的Range对象的引用,ListIndex属性返回所选项在列表中的位置,作为List属性的索引值返回具体的列表项。...4.与使用数据验证不同的是,本文介绍的代码方法更灵活,在你需要选择列表项时双击鼠标,要自已输入不在列表项中的数据时可直接输入。
一: 使用场景 在日常的系统开发中,系统支持批量数据的操作是一个很常见的功能,其中,最常用的方式是使用excel表格对数据进行批量添加、删除,如:批量新建订单、批量添加商品等。...二: 技术选型 现在市面上有很多技术实现来支持excel数据解析如:POI、JXL等,但是,这些技术或多或少都存在着一些问题,下面进行具体分析: (一): POI POI是目前使用最多的用来做excel...现在使用POI技术来解析excel文件的,大多数都是使用到它的userMode模式,好处是上手比较简单,而且网上比较多封装好的代码,虽然复制一下就可以运行,这个对于数据量不大的文件的时候是可以使用,但是当数据量大的时候会存在巨大隐患...3、在大并发情况下,POI还存在着一些未知的错误,如果需要POI团队修复,周期不确定。...在尽可能节约内存的情况下支持读写百M的Excel,选择使用它有以下原因: 1、开源,代码放在github上,有问题随时issue 2、解决了POI解析excel非常耗费内存的问题,它是通过磁盘存储,
最近在做这样的一个需求: 我们有几套相似的后台,其中的表结构还不是完全一致,但是后台的菜单功能基本相同,我们想把这几个后台合并到一个后台中,通过下拉菜单进行后台的切换。以下简称总后台和子后台。...所以这里在总后台上加上了一个拦截器,用于拦截所有的请求,然后做出判断,使用httpclient工具,将请求发送到对应的子后台,得到数据后,返回到response中,实现需求。...log.error(e.getMessage(), e); } JsonUtil.write(out,resMap); 但是有一类需求发现使用这种方式做处理无法得到预期结果...那就是系统中还存在部分excel导出功能,都是使用poi做实现的。由于poi中自动实现了对于response和输出流的处理,使用上面的方式是没有办法实现的。...那么我使用httpclient如何调用另一个系统写好的poi导出功能呢。 我们先看一下子系统中poi的实现方式。
1、点击[数据] 2、点击[数据验证] 3、点击[数据验证] 4、点击[任何值] 5、点击[序列] 6、点击[来源] 7、点击[确定]
学习Excel技术,关注微信公众号: excelperfect 在网站中,我们经常会碰到需要一层层向下选择的情况。在第一个选项列表中选择第一个数据,第二个选项列表中选择第二个数据,依此类推。...并且,后面的选项列表内容会根据前面选择的内容而发生变化。如下图1所示。 ? 图1 上图1是使用Excel VBA用户窗体实现的效果,实现起来很简单。 首先,准备数据,如下图2所示。...第1列单元格中的值分别是该列下方数据单元格区域的名称,这需要我们事先使用名称功能进行定义。 ? 图2 接着,设计用户窗体,如下图3所示。...在VBE中,插入一个用户窗体,在上面放置3个组合框并分别命名为:cmbProduct、cmbModel和cmbSubModel。 ?...'在第2个组合框中添加相应的值 Case "产品1" cmbModel.List =Application.WorksheetFunction.Transpose(Range
前言 在Excel 中,依赖列表或级联下拉列表表示两个或多个列表,其中一个列表的项根据另一个列表而变化。...在此博客示例中,此主下拉列表在单元格 L3 中创建。 使用 GcExcel,使用 IRange 接口的 API 在某个范围内配置数据验证。...步骤 5 - 获取唯一 OrderID 列表(用于依赖下拉列表) 准备好主下拉列表后,让我们获取在主下拉列表中选择的客户名称的唯一 OrderID 列表。...下一步是使用上一步中提取的列表填充 OrderID 下拉列表(在此示例中,它位于 L6)。...Excel 文件如下图所示: 总结 以上就是使用C#生成依赖列表的全过程。
uniapp 的坑还是很多 $refs在app或者支付宝小程序里不可用 显示undefined 解决办法this.
//创建Excel对象,此时未使用 temp file SXSSFWorkbook wb = new SXSSFWorkbook(1000); //temp files will be gzipped...wb.setCompressTempFiles(true); //注意:以下语句将会使用 temp file Sheet sh = wb.createSheet(title); 如果 tomcat 下无...(GZIPSheetDataWriter.java:39) at org.apache.poi.xssf.streaming.SheetDataWriter....(SheetDataWriter.java:49) at org.apache.poi.xssf.streaming.GZIPSheetDataWriter....(SXSSFWorkbook.java:239) at org.apache.poi.xssf.streaming.SXSSFSheet.
rowNum, colNum,dvHelper); sheet.addValidationData(data_validation_list); } /** * 加载下拉列表内容...", "请使用下拉方式选择合适的值!")...; // 设置输入错误提示信息 //data_validation_list.createErrorBox("选择错误提示", "你输入的值未在备选列表中,请下拉选择合适的值...", "请使用下拉方式选择合适的值!")...; // 设置输入错误提示信息 //data_validation_list.createErrorBox("选择错误提示", "你输入的值未在备选列表中,请下拉选择合适的值
前言 “导出一个 Excel 文件难吗?可能你已经使用了许多第三方工具来实现这个功能,但今天我要向你介绍 Apache POI。...它不仅仅是导出 Excel,它还能让你精确控制每一个单元格的格式、数据类型和样式。想象一下,几行代码就能生成一个定制化的表格!接下来,让我们一起来看看这个工具有多么强大。”...内存消耗:所有的 Excel 数据都会加载到内存中,处理大文件时会出现内存不足的情况。 适用场景:适合处理较小的旧版 .xls 文件,当数据量不大时可以使用。...适用场景:特别适合导出大数据量的 Excel 文件,因为它不会消耗太多内存。默认只保留一定数量的行在内存中,其他行会写入到磁盘的临时文件中。...(cell.getStringCellValue()); } } } // Step 2: 将这些唯一值转换为下拉选项列表
不知大家是否有过类似的经历,比如说for循环渲染数组或者对象中的数据,渲染完成后,给数组或者对象添加、修改、删除数据后却没有在页面中渲染出来。...本篇就是来解释说明修改数组和对象数据视图立马更新的问题,要掌握各种情况和set、delete方法的使用 数组中数据渲染后的修改、新增、删除问题 <!...、splice、sort、reverse 修改可以splice,新增可以push、unshift、splice,根据需要使用、删除可以splice、unshift、pop,根据需要使用 或者直接改引用,...综上所述,数组要能直接触发视图更新在页面上渲染出来的方法 1.利用数组的api方法 2.改变数组指向的内存地址(改引用) 3.利用Vue的set、delete方法操作数组(推荐) 对象中数据渲染后的修改...$delete(vm.userInfo, "age") 经过我的测试这都是可以的,根据需要使用 综上所述 虽然修改数组、对象中的数据都可以直接改变引用地址实现,但是不推荐。
前言 当你学习不熟悉的新东西的时候,一旦发现某样东西有效,那么你就会坚持使用它而放弃探索更多的可能性。在Python中,那样东西就是列表。 使用列表的感觉就像是在一直重复你最喜欢的特别动作。...然后Python不止列表,还有元组和集合。让我们回顾一下这些特殊的数据类型,并且说明在什么情境下应该使用它们而不是列表。 ? 元组 元组是不变的有序项目序列。最后一个词——不可变——是这里的秘密武器。...使用元组的语法几乎与列表相同,只是使用了括号而不是方括号。此外,还可以将列表转换为元组。...一开始可能会觉得不方便;但是,每次使用元组而不是列表时,您都会做两件事。 编写更加语义化和安全的代码。当您将变量定义为元组时,您是在告诉自己和代码的任何其他查看者:“这不会改变”。...遍历元组将比遍历列表更快。元组比列表的内存效率更高。由于元组中的项数没有变化,因此它的内存占用更简洁。 如果您的列表的大小没有被修改,或者其目的仅仅是用于迭代,那么尝试用元组替换它。 ?
poi是读写excel最常用的一个开源中间件,实际使用中我们可能会遇到这样的需求:限制某列单元格只能输入特定的内容,这就是excel的下拉列表特性,以下是wps中excel的一个截图: 从上图可以看出...,维护下拉选项有两种方式: 1.手动添加下拉选项 2.从单元格选择下拉选项 第一种方式的缺点就是单元格字节数不能超过255个字,笔者在实际使用中输入的内容远超过这个数,所以笔者选择的是第二种方案,笔者新建了一个...sheet,在这个sheet中某列输入实际需要的下拉列表内容(可以动态插入),比如省市,然后隐藏这个sheet即可,这样用户在使用过程中就可以根据这个模板文件输入限制的内容。...help.createValidation(constraint, regions); sheet.addValidationData(validation); 上面的代码就可以实现exel的下拉列表选择功能...,而且不限制下拉列表长度!!
一、简介 在使用EasyExcel设置下拉数据时,每次都要创建一个SheetWriteHandler组件确实比较繁琐。...三种方式都是通过此注解实现 /** * 定义Excel列下拉列表属性的注解。...创建后设置下拉列表 在隐藏的sheet中存储下拉选项,然后设置数据验证以实现下拉功能 最后这里添加了阻止输入非下拉选项的值的校验 /** * 处理Excel下拉列表的SheetWriteHandler...创建后调用的方法,用于设置Excel下拉列表。...sheet中生成下拉列表选项值。
最近在做一个将excel导入到报表中的功能,使用了POI来实现,发现POI使用有诸多不便之处,先记录下来,以后可能考虑使用Openxml。 1....数值类型处理 通过POI取出的数值默认都是double,即使excel单元格中存的是1,取出来的值也是1.0,这就造成了一些问题,如果数据库字段是int,那么就会wrong data type...longVal + ".0") == doubleVal) inputValue = longVal; else inputValue = doubleVal; } 这么处理后,单元格中的小数没有变化...日期类型处理 很遗憾,POI对单元格日期处理很弱,没有针对的类型,日期类型取出来的也是一个double值,所以同样作为数值类型。...数据有效性 很奇怪,POI能生成数据有效性(下拉列表),却得不到,或者说我没找到方法去得到,蛋疼。
问题 在SpringBoot项目中使用WebSocket的过程中有其他的业务操作需要注入其它接口来做相应的业务操作,但是在WebSocket的Server类中使用Autowired注解无效,这样注入的对象就是空...,在使用过程中会报空指针异常。...注释:上面说的WebSocket的Server类就是指被@ServerEndpoint注解修饰的类 原因 原因就是在spring容器中管理的是单例的,他只会注入一次,而WebSocket是多对象的,当有新的用户使用的时候...WebSocket对象,这就导致了用户创建的WebSocket对象都不能注入对象了,所以在运行的时候就会发生注入对象为null的情况; 主要的原因就是Spring容器管理的方式不能直接注入WebSocket中的对象