excel 宏(VB)实现复制一列并按第二列的单元格长度排序

本文介绍了一个利用VBA(Visual Basic for Applications)编写宏,通过复制、粘贴和排序操作来实现Excel中特定列数据的高效管理。具体步骤包括选择目标列、复制数据、插入数据到右侧并进行排序。特别地,宏利用了Excel的公式和函数(如LEN)来按列长度自动排序数据,从而简化了常规排序操作。最后,宏确保所有操作在完成之后自动保存工作簿。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Sub 复制排序()

    Columns("B:B").Select
    Selection.Copy
    Columns("C:C").Select
    Selection.Insert Shift:=xlToRight
    Range("E1").Select
    Application.CutCopyMode = False
    

'排序的话应该有更好的方式,直接按单元格长度排序,没时间弄

    Dim t As Double


    t = ActiveSheet.[A1048576].End(xlUp).Row '针对EXCEL2010
    
    
    ActiveCell.FormulaR1C1 = "=LEN(RC[-2])"
    Range("E1").Select
    Selection.Copy
    Range(Cells(t, 5), Cells(1, 5)).Select
    ActiveSheet.Paste
    Application.CutCopyMode = False
    
        ActiveSheet.Sort.SortFields.Clear
    ActiveSheet.Sort.SortFields.Add Key:=Range("E1"), _
        SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal
    With ActiveSheet.Sort
        .SetRange Range(Cells(1, 1), Cells(t, 5))
        .Header = xlNo
        .MatchCase = False
        .Orientation = xlTopToBottom
        .SortMethod = xlPinYin
        .Apply
    End With
    ActiveWorkbook.Save
    
    
End Sub



Excel VB编程; 页面material input 输入的是物料编码(A列)和数量(B列),输入区是从第二行开始,页面Database页面物料号(A列)以及物料的采购单价(B列),同样数据区从第二行开始。要求如下: 1)点击material input 页面控件按钮后,根据material input 输入的采购物料号和数量,从Database获取物料号对应的采购单价,计算物料采购单价*数量=每个物料采购成本。总的采购成本=所有物料的采购成本之和累计相加。 2)如果material input 页面有重复的物料号输入,需要将同一物料号的采购成本进行合。合的计算规则是:将同一物料号的数量相加和*采购单价=同一物料号的采购成本, 3)弹窗提醒“将进行累加计算,请确认清除输入区信息”,先检查页面cost analysis的B4~C23区域是否有物料成本数据(B列为物料号,C列为采购成本),以及cost analysis页面B2单元格已经有的采购物料总成本值,此区域的信息读取记录,依据新输入计算的物料号的采购成本和已经读取的cost analysis的物料采购成本重新一起排序重新输出TOP20个物料采购成本依次输出到页面cost analysis的B4~C23区域。将B2单元格既有的采购总成本值+依据输入的物料采购成本总值=新的采购总成本累加值,重新输出覆盖cost analysis页面B2单元格。 4)如material input 页面所输入的物料号在database页面未查找到,一个弹窗提醒所有无采购单价的物料号清单,将无采购单价的物料号依次输出到页面material input G列不为空的单元格
03-18
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值