0

查看此页面上的示例https://www.extendoffice.com/documents/excel/3269-excel-concatenate-cells-if-not-empty.html(如下所示)。

如果最后一个条目为空,则此解决方案不起作用。例如,在 A 列中,如果 A5 中缺少“订单”,则结果将是“KTE-2015-Ruby-”而不是“KTE-2015-Ruby”。

如果没有一堆 if 语句检查该单元格是否是最后一个不为空白的单元格,我将如何获得第二个结果。

有关更多信息,我将始终必须检查相同数量的信息行,但实际包含文本的行数是不确定的。再次以图片为例,我将始终只检查第 1-5 行,但我不知道哪些行是空白的。

在此处输入图像描述

4

2 回答 2

1

如果您有 Office 365 Excel,则可以使用 TEXTJOIN():

=TEXTJOIN("-",TRUE,A1:A5)

如果没有,那么您需要添加到公式中以使用 LEFT() 删除最后一个字符

=LEFT(A1 & "-" & IF(A2<>"",A2 & "-","") & IF(A3<>"",A3 & "-","") & IF(A4<>"",A4 & "-","") & IF(A5<>"",A5 & "-",""),LEN(A1 & "-" & IF(A2<>"",A2 & "-","") & IF(A3<>"",A3 & "-","") & IF(A4<>"",A4 & "-","") & IF(A5<>"",A5 & "-",""))-1)

这个公式有点不同,因为它总是-在末尾添加。-然后它用 Left删除最后一个。那么无论是否有空白都没有关系,我们总是有-需要删除的末尾。


或者正如@Jeeped 所说:

=MID(IF(A1<>"","-" & A1,"") & IF(A2<>"","-" & A2,"") & IF(A3<>"","-" & A3,"") & IF(A4<>"","-" & A4,"") & IF(A5<>"","-" & A5,""),2, 999999)
于 2017-06-16T15:31:37.963 回答
1

连接有限数量的可能字符串时,如果您无权访问 TEXTJOIN,也可以使用 SUBSTITUTE 和 TRIM。

=SUBSTITUTE(TRIM(A2&" "&B2&" "&C2), " ", "-")

在此处输入图像描述

于 2017-06-16T15:51:50.813 回答