ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 14646|回复: 29

[讨论][求助]如何按条件连接字符串,并加入参数说明。

[复制链接]

TA的精华主题

TA的得分主题

发表于 2006-3-23 11:40 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖已被收录到知识树中,索引项:自定义函数开发

如何按条件连接字符串。
将相同条件的字符串连接起来。
具体要求见附件。 5s3PZIJo.zip (13.34 KB, 下载次数: 159)

有会员朋友提问,就想起了这个贴子.自定义函数加说明的方法加1分. qee用

[此贴子已经被qee用于2007-7-1 4:45:51编辑过]

IUw6OYPV.zip

1.59 KB, 下载次数: 171

[求助]如何按条件连接字符串。

TA的精华主题

TA的得分主题

发表于 2006-3-23 11:43 | 显示全部楼层
用VBA吧

TA的精华主题

TA的得分主题

 楼主| 发表于 2006-3-23 11:54 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

怎么用?帮帮忙看一下?

可不可以做个函数
[此贴子已经被作者于2006-3-23 11:55:29编辑过]

TA的精华主题

TA的得分主题

发表于 2006-3-23 12:14 | 显示全部楼层
Sub Mxr()
Dim n
Range("A1:B" & [A65536].End(xlUp).Row).Select
Selection.Sort Key1:=Range("A2"), Order1:=xlAscending, Header:=xlYes, _
OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, SortMethod _
:=xlPinYin, DataOption1:=xlSortNormal

For n = 2 To [A65536].End(xlUp).Row
If Cells(n, 1) = Cells(n + 1, 1) Then
Cells(n, 3) = Cells(n, 2) & "*" & Cells(n + 1, 2)
End If
Next
End Sub

TA的精华主题

TA的得分主题

发表于 2006-3-23 12:35 | 显示全部楼层
[c2]=linksamepro(A2)
Function LinkSamePro$(ByVal pro As Range)
Dim rg As Range
For Each rg In Range("A1:A" & [a65535].End(xlUp).Row)
If rg.Text = pro.Text Then LinkSamePro = LinkSamePro & "*" & rg.Offset(0, 1).Text
Next rg
LinkSamePro = Mid$(LinkSamePro, 2)
End Function

TA的精华主题

TA的得分主题

 楼主| 发表于 2006-3-23 12:57 | 显示全部楼层

谢谢楼上的两位。

qee用: 请问可不可这样引用:C2=linksamepro(A2:A5,A2,B2:B5),能不能再进一步改一下。 也就是在具体的范围内求结果。 热盼。
[此贴子已经被作者于2006-3-23 13:13:36编辑过]

TA的精华主题

TA的得分主题

发表于 2006-3-23 15:11 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

借用qee用兄弟的函数:

Function LinkSamePro$(ByVal R As Range, ByVal pro As Range)
Dim rg As Range, x() As String, i As Integer
For Each rg In R
If rg.Text = pro.Text Then
i = i + 1
ReDim Preserve x(1 To i)
x(i) = rg.Offset(0, 1)
End If
Next
LinkSamePro = Join(x, "*")
End Function

C2=linksamepro(A$2:A$5,A2)

TA的精华主题

TA的得分主题

发表于 2006-3-23 15:18 | 显示全部楼层

谢谢northwolves兄!
我现在是网通的用户,刷新一次届面就要几分钟.
刚才发了几次都没发出去.把你的要求修改一下可以吗?
[C2]=linksamepro2(A2:A5,A2,1)第三个参数表示偏移量
Function LinkSamePro2$(ByVal proIN As Range, ByVal pro As Range, ByVal ofs As Integer)
Dim rg As Range
For Each rg In proIN
If rg.Text = pro.Text Then LinkSamePro2 = LinkSamePro2 & "*" & rg.Offset(0, ofs).Text
Next rg
LinkSamePro2 = Mid$(LinkSamePro2, 2)
End Function

TA的精华主题

TA的得分主题

 楼主| 发表于 2006-3-23 15:29 | 显示全部楼层

QEE和northwolves:你们好。

能不能将函数改成这样,如可以怎么改。

Function LinkSamePro2$(ByVal proIN As Range, ByVal pro As Range, ByVal valueC As Range )

不知可不可跨sheet表引用。

C2=linksamepro(A2:A5,A2,B2:B5); 就像SUMIF(range,criteria,sum_range)

不要嫌我烦啊,谢谢。

[此贴子已经被作者于2006-3-23 15:58:32编辑过]

TA的精华主题

TA的得分主题

发表于 2006-3-23 16:13 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
Function LinkSamePro3$(ByVal proIN As Range, ByVal pro As Range, ByVal proOfs As Range)
Dim rg As Range
Dim i%
i = 0
For Each rg In proIN
If rg.Text = pro.Text Then
LinkSamePro3 = LinkSamePro3 & "*" & proOfs.Cells(1).Offset(i, 0).Text
End If
i = i + 1
Next rg
LinkSamePro3 = Mid$(LinkSamePro3, 2)
End Function
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-26 12:06 , Processed in 0.043804 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表