Excel vba 问题, Target.Address 怎么返回 RC格式,或者只返回列?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Excel vba 问题, Target.Address 怎么返回 RC格式,或者只返回列?相关的知识,希望对你有一定的参考价值。

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Cells(1.1) = Target.Address
End Sub

就是我只想在A1输出列的数字,比如A列输出1.C列输出3

参考技术A 那就别用地址,用列标啊:
Target.Column
行标是:
Target.Row追问

噢,好!!!

本回答被提问者采纳

请教excel汇总问题。vba

请教下 我有一个表 A列 日期 B列 供应商 C列 产品 列数量 B列和C列是多对多关系 我想新建一个表统计 A 列供应商 B列产品 C列统计各日期的产品总和。第一图为实际图。第2图为要达到的效果图。求VBA的编写方式 谢谢。
我的2859782009

参考技术A sub 合并()
dim d,arr,r&
Set d= CreateObject("Scripting.Dictionary")
arr=sheets(1).usedrange.value
for r=2 to ubound(arr)
   d(arr(r,2)&"+"&arr(r,3))= d(arr(r,2)&"+"&arr(r,3))+arr(r,4)
next 
with sheets(2)
     .[a2].resize(d.count,1)=application.transpose(d.keys)
     .Range("a2:a"&d.count+1).TextToColumns Destination:=Range("a2"), Other:=True, OtherChar:="+"  
     .[c2].resize(d.count,1)=application.transpose(d.items)
end with
set d=nothing
end sub

怎么感觉和其他题有点像

没有excel,没调试

==================

修改下,试试看吧

追问

麻烦在帮忙看看。谢谢

追答

excel卸掉了还没装好。。下载速度太慢了
首先你要确定你第一张图的sheet名 。。还有第二张图的sheet名
sheets(1)=改成 sheets(" ") 双引号内填上你源数据的表名 。注意,双引号也是要的
sheets(2) 同上

如果还不知道怎么做,可以新建两个表, 一张表叫源数据,把你第一图上的所有数据复制去,第于个表叫汇总。a1:c1填上字段名就可以了
然后,sheets(1) 改成 sheets("源数据")
sheets(2) 改成 sheets("汇总")

追问

sheets(1) 名字就是sheets(1)
sheets(2)表新建一个表生成数据 名字

追答

你确定?
算了,也有人回复了,我相信你现在应该也成功了,
好吧,祝 好运。。

参考技术B 这个用一个字典,以B-C列为关键字,item表示各个key的和,然后split拆分即可得到你想要的表格!!追问

能不能说傻瓜一点呵呵。我不知道具体该怎么做。帮帮忙

追答

以下是代码,请测试!

Sub FLHZ()
    Dim dc As Object, arr
    Set dc = CreateObject("Scripting.Dictionary")
    arr = Range("B2:D" & [b65536].End(3).Row)
    Dim i As Long
    For i = 1 To UBound(arr)
        dc(arr(i, 1) & "-" & arr(i, 2)) = Val(dc(arr(i, 1) & "-" & arr(i, 2))) + arr(i, 3)
    Next
    
    Dim ar
    ar = dc.keys
    With Sheet2
       .[a1] = "供应商"
       .[b1] = "药品"
       .[c1] = "数量汇总"
        For i = 0 To UBound(ar)
            .Cells(i + 2, "A") = Split(ar(i), "-")(0)
            .Cells(i + 2, "B") = Split(ar(i), "-")(1)
            .Cells(i + 2, "C") = dc(ar(i))
        Next
       .Range("A2:C" & .[c65536].End(3).Row).Sort key1:=.[a2], key2:=.[b2]
    End With
    
    MsgBox "汇总完毕!"
    Sheet2.Activate
    Sheet2.[a1].Select
End Sub


本回答被提问者采纳
参考技术C 这个不用VBA,用数据透视表都可以达到你的要求哦。追问

数据透视表  alt+d+p 多重合并计算区域 出来的效果。

不知道是操作没对还是啥情况

追答

直接QQ说话?

追问

2859782009 。谢谢

参考技术D 一定要用VBA吗?用数据透视表简单几步就可实现你的要求。追问

帮忙讲讲 谢谢。我可能操作不对。

追答

选择B、C、D列,点菜单-数据-数据透视表,建立透视表,在当前表点一个位置,下一步,布局,将供应商拖入列、药品拖入行,数量拖入数据,确定即可。

以上是关于Excel vba 问题, Target.Address 怎么返回 RC格式,或者只返回列?的主要内容,如果未能解决你的问题,请参考以下文章

请教,在Excel 中使用VBA查找问题。

excel vba 运行时错误

EXCEL VBA防盗代码哪里有问题,求帮忙修改。

EXCEL VBA 求助

Excel 2016 VBA - 从 Excel 2013 升级的问题

EXCEL VBA 事件的问题。