左侧固定右侧自动填充_Excel – 按随机指定的数字,自动调整间隔行数填充背景色...

给数据表隔行填充颜色,在工作中是个利人利己的操作,不仅自己工作时便利,更重要的是在汇报工作的时候方便领导查看。

如何隔行填充背景色?除去填充一行后,再用格式刷复制这种手动操作我不太推荐外,江湖上经常用到的是 Ctrl+T 变成超级表,自动隔行填充,或者就是用公式。

说到用公式,我曾经写过类似的案例,比如 Excel – 忽略隐藏行,自动隔行填充背景色 。

今天再教大家一个新玩法:如何按指定的分隔行数自动改变填充规则。

案例:

按照 G2 单元格中规定的间隔行数,自动对左侧数据表区域隔若干行填充。

效果如下图 2 至 4 所示。

8c5627060cd221733408fccadbfcd8ae.png
f6da0a6ab8b2fa11889b6b7753f5abcb.png
878d67a3596a688d8ef7554238e847cd.png
0a944ea1e23abbe56e17b8ababe678e7.png

解决方案:

1. 选中 A2:E25 区域 --> 选择菜单栏的“开始”-->“条件格式”-->“新建规则”

096bd66e88875446d9a8690c0658cd11.png

2. 在弹出的对话框中选择“使用公式确定要设置格式的单元格”--> 在公式区域输入以下公式 --> 点击“格式”按钮:

=MOD(ROW(A1),$G$2+1)=0

公式释义:

  • ROW(A1):A1 单元格的行值,即 1;条件区域中的单元格是活动的,因此相当于在区域内按自然数递增
  • MOD(..,$G$2+1):
    • mod 函数的作用是求余数,即上述行值除以 $G$2+1,得到的余数;
    • $G$2 绝对引用,即表示分母的值是固定不变的;
    • 如果要隔 2 行填充,也就是要在第 3 行及其倍数行填充,即需要填充的行数除以 3 的余数应该为 0,因此分母必须是 $G$2 的值 +1;
    • 当 $G$2 的值为 2 时,区域内 MOD(ROW(A1),$G$2+1) 公式的值为 {1;2;0;1;2;0;1;2;0;1;2;0;1;2;0;1;2;0;1;2;0;1;2;0};所有为 0 的行就是需要填充的,因此公式 =0 时触发条件
7184d7ef5ea0d8b80639bfe35e5b7d4c.png

3. 在弹出的对话框中选择所需的填充色 --> 点击“确定”:

76af2680873d42596f778e11eafca58e.png

4. 点击“确定”

7e9b9f8a94532f0afa4aea5eb875e627.png

现在所有单元格都填充了颜色,这是因为 G2 单元格中尚未输入数值,会被视作 0,也就是隔 0 行填充,因此所有行都填充了颜色。

4de1f3108b3fea4fdb25135d44394f63.png

修改 G2 单元格中的数值,左侧的数据表就会自动按 G2 单元格规定的间隔数填充背景色。

e9cfc4bca0404a921762e164885edbbb.gif

很多同学会觉得 Excel 单个案例讲解有些碎片化,初学者未必能完全理解和掌握。不少同学都希望有一套完整的图文教学,从最基础的概念开始,一步步由简入繁、从入门到精通,系统化地讲解 Excel 的各个知识点。

现在终于有了,以下专栏,从最基础的操作和概念讲起,用生动、有趣的案例带大家逐一掌握 Excel 的操作技巧、快捷键大全、函数公式、数据透视表、图表、打印技巧等……学完全本,你也能成为 Excel 高手。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以通过以下步骤来实现基于 Java POI 的 Excel 表格下拉框选择一个值,另一个单元格自动填充内容的功能: 1. 创建一个 Excel 文件对象,并获取工作表对象。 ```java Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("Sheet1"); ``` 2. 创建一个带有选项列表的单元格,并将其添加到工作表中。 ```java // 创建一个带有选项列表的单元格 DataValidationHelper validationHelper = new XSSFDataValidationHelper(sheet); DataValidationConstraint constraint = validationHelper.createExplicitListConstraint(new String[]{"选项1", "选项2", "选项3"}); CellRangeAddressList addressList = new CellRangeAddressList(0, 0, 0, 0); DataValidation validation = validationHelper.createValidation(constraint, addressList); // 将单元格添加到工作表中 Row row = sheet.createRow(0); Cell cell = row.createCell(0); cell.setCellValue("选择选项:"); cell.setAsActiveCell(); sheet.addValidationData(validation); ``` 3. 创建一个监听器来处理选项列表单元格的更改事件,并在另一个单元格中填充相应的内容。 ```java // 创建监听器 sheet.addValidationListener(new ValidationListener() { @Override public void onChange(DataValidation validation) { // 获取选项列表单元格的值 CellReference cellRef = validation.getRegions().getCellRangeAddress(0).getFirstCell(); Row row = sheet.getRow(cellRef.getRow()); Cell cell = row.getCell(cellRef.getCol()); String selectedValue = cell.getStringCellValue(); // 根据选项列表单元格的值填充另一个单元格 Cell targetCell = row.createCell(1); if (selectedValue.equals("选项1")) { targetCell.setCellValue("填充内容1"); } else if (selectedValue.equals("选项2")) { targetCell.setCellValue("填充内容2"); } else if (selectedValue.equals("选项3")) { targetCell.setCellValue("填充内容3"); } } @Override public void onInvalid(DataValidation validation) { // 处理无效数据 } }); ``` 4. 将 Excel 文件保存到磁盘上。 ```java FileOutputStream outputStream = new FileOutputStream("example.xlsx"); workbook.write(outputStream); outputStream.close(); ``` 以上就是实现基于 Java POI 的 Excel 表格下拉框选择一个值,另一个单元格自动填充内容的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值