格子中输出

本文介绍了一个名为stringInGrid的方法,该方法能够在指定大小的网格中将字符串居中打印。如果字符串过长,则进行截断处理。文章提供了实现这一功能的Java代码示例。
stringInGrid方法会在一个指定大小的格子中打印指定的字符串。
要求字符串在水平、垂直两个方向上都居中。
如果字符串太长,就截断。

如果不能恰好居中,可以稍稍偏左或者偏上一点。

对于题目中数据,应该输出:


源码如下,只需填写“填空”的位置:

public class Main {  
    
	public static void main(String[] args) {
				
		stringInGrid(20, 6, "abcd1234");
		
	}
	

	public static void stringInGrid(int width, int height, String s){
	
		if(s.length()>width-2) s = s.substring(0,width-2);
		
		System.out.print("+");
		
		for(int i=0;i<width-2;i++) System.out.print("-");
		
		System.out.println("+");
		
		for(int k=1; k<(height-1)/2;k++){
			
			System.out.print("|");
			
			for(int i=0;i<width-2;i++) System.out.print(" ");
			
			System.out.println("|");
		}
		
		System.out.print("|");
		
		String ff =(width-s.length()-2)==0?s:"%"+((width-s.length()-2)/2)+"s%s%"+((width-s.length()-1)/2)+"s";  //填空
		
		System.out.print(String.format(ff,"",s,""));
		          
		System.out.println("|");
		
		for(int k=(height-1)/2+1; k<height-1; k++){
			
			System.out.print("|");
			
			for(int i=0;i<width-2;i++) System.out.print(" ");
			
			System.out.println("|");
		}	
		
		System.out.print("+");
		
		for(int i=0;i<width-2;i++) System.out.print("-");
		
		System.out.println("+");	
		
	}
	
}  


在 Excel 中实现基于通配符匹配的多行数据查找,并输出所有符合条件的整行数据,是一项对函数能力要求较高的操作。尤其当数据量达到 50 万行时,需要选择性能较强且能够避免使用辅助列的方法来完成。 ### 使用 `FILTER` 函数结合通配符进行模糊匹配 如果使用的是支持动态数组公式的 Excel 版本(如 Excel 365 或 Excel 2019 及以上),推荐使用 `FILTER` 函数配合 `SEARCH` 实现通配符匹配: ```excel =FILTER(A2:D500001, ISNUMBER(SEARCH("*关键词*", C2:C500001)), "无匹配结果") ``` 该公式中: - `A2:D500001` 是完整的数据区域。 - `"*关键词*"` 表示包含“关键词”的任意位置字符串,实现了类似通配符的模糊匹配功能。 - `C2:C500001` 是目标列范围。 - 若未找到匹配项,则返回“无匹配结果”[^2]。 此方法无需使用辅助列,且能直接输出所有符合条件的整行数据,适用于大规模数据处理场景。 ### 使用 `INDEX` + `SMALL` + `IF` + `SEARCH` 的组合公式 对于不支持动态数组公式的 Excel 版本,可以通过数组公式的方式实现类似功能,具体如下: ```excel =INDEX($A$2:$D$500001, SMALL(IF(ISNUMBER(SEARCH("*关键词*", $C$2:$C$500001)), ROW($C$2:$C$500001)-ROW($C$2)+1), ROW(1:1)), COLUMN(A1)) ``` 该公式需按 `Ctrl+Shift+Enter` 输入为数组公式,并向右、向下拖动以填充整个结果区域。通过 `SEARCH` 函数实现通配符匹配,结合 `INDEX` 和 `SMALL` 动态提取符合条件的行号和列值,最终输出整行数据[^2]。 ### 性能优化建议 - **避免全列引用**:如非必要,应限定具体范围(如 `C2:C500001`),而不是使用 `C:C` 等全列引用,以减少计算负担。 - **关闭自动计算**:在处理前将公式计算方式设为手动,完成后再恢复自动计算。 - **使用 64 位 Excel**:64 位版本可支持更大内存,更适合处理大数据量。 上述方法均能在不使用辅助列的前提下,实现基于通配符的多行数据查找,并输出整行结果,适用于大规模数据集中的高效查询需求。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值