注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

零售创新,创新那些事儿,SPSS,VBA

零售创新

 
 
 

日志

 
 
关于我

新浪微博,零售创新 研究经理,数据分析师 希望和市场研究和零售业的同事共同进步! 本博客发表的都是免费或试用的资料,如果有版权问题请发邮件wangli12a@163.com联系删除。 spss excel vba blog

网易考拉推荐

Excel VBA 营销人员利器,行列转换宏  

2015-02-07 10:26:39|  分类: VB和VBA知识 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
Excel VBA 营销人员利器,行列转换宏 - 和平 - 零售创新,创新那些事儿,SPSS,VBA
 
Excel VBA 营销人员利器,行列转换宏
同事在做抽奖名单的时候有一个小问题,几千个名单要转成行,一个一个转实在是要半天,写了一个简单的宏,完美解决。
 http://vdisk.weibo.com/s/zvGCXgbY9rUdC
 

Excel VBA 营销人员利器,行列转换宏 - 和平 - 零售创新,创新那些事儿,SPSS,VBA
 

Function getColumnLetter(ByVal myCol As Integer) As String  '获取单元格列标的字母
    Dim columnName As String
    Dim k As Integer
    k = (myCol - 1) \ 26
    Select Case k
        Case 0
        Case Else
            columnName = columnName & Chr(64 + k)
    End Select
    columnName = columnName & Chr(64 + ((myCol - 1) Mod 26) + 1)
    'MsgBox "列标号为 " & myCol & " 的单元格的列标字母为 " & columnName
   getColumnLetter = columnName

End Function


Sub 名单生成()
'
' 宏1 宏
'
Dim ming(900000)

Dim range1 As String



aa = getColumnLetter(Sheets("名单").Cells(5, 2))

ab = Sheets("名单").Cells(5, 10)
r = Sheets("账号").Cells(Rows.Count, aa).End(xlUp).Row



'

For i = 1 To r - 1
ming(i) = Sheets("账号").Cells(i + 1, aa)
Next


Sheets("名单").Select

k = 10



For l = 1 To r - 1
k1 = 1

tt = l Mod ab
'
If tt = 0 Then
tt1 = ab
Else
tt1 = tt
End If

Cells(k, tt1) = ming(l)


If tt = 0 Then
k = k + 1
End If



Next

End Sub


Sub 清空()

Sheets("名单").Select
   a = 10
    b = 1048576
Rows(a & ":" & b).ClearContents '行清除内容
Rows(a & ":" & b).Clear '行全部清除

Cells(1, 1).Select
End Sub

  评论这张
 
阅读(614)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017