Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
楼主: 爱疯

[已解决]转弯问题

[复制链接]
发表于 2009-12-3 14:15 | 显示全部楼层

QUOTE:
以下是引用大灰狼在2009-12-3 14:14:00的发言:

空多少列那个inputbox是不是多余了?

两列一个step是固定的呀?还是我没看懂?

不是多余的,你试试看楼主的源程序里面输入一个2或者3看看效果。

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
回复

使用道具 举报

发表于 2009-12-3 14:18 | 显示全部楼层

QUOTE:
以下是引用大灰狼在2009-12-3 14:12:00的发言:

Sub Turn()
    Dim RoMax As Byte
    Dim Ro As Byte
    Dim Col As Byte
    Dim ColMax
    Dim Cnt As Byte
    With ThisWorkbook.Sheets(1)
        .UsedRange.Clear
        RoMax = Application.InputBox("Input max row:", Default:=20)
        ColMax = (56 \ RoMax) * 2 + 1
        For Col = 1 To ColMax Step 2
            For Ro = 1 To RoMax
'                Cnt = (Col \ 2) * RoMax + Ro'这个地方其实都不用这样计算,可以直接从1开始计数了,所以简化成cnt=cnt+1
                Cnt = Cnt + 1
                If Cnt = 57 Then Exit Sub
                .Cells(Ro, Col).Interior.ColorIndex = Cnt
                .Cells(Ro, Col + 1) = Cnt
            Next Ro
        Next Col
    End With
End Sub

这个思路和我一样

[em01]
回复

使用道具 举报

发表于 2009-12-3 14:20 | 显示全部楼层

那我又改了一下
Sub Turn()
    Dim RoMax As Byte
    Dim Ro As Byte
    Dim Col As Byte
    Dim ColMax
    Dim Cnt As Byte
    Dim Stp As Byte
    With ThisWorkbook.Sheets(1)
        .UsedRange.Clear
        RoMax = Application.InputBox("Input max row:", Default:=20)
        Stp = Application.InputBox("Input max colume:", Default:=0)
        ColMax = (56 \ RoMax) * (2 + Stp) + 1
        For Col = 1 To ColMax Step 2 + Stp
            For Ro = 1 To RoMax
                Cnt = Cnt + 1
                If Cnt = 57 Then Exit Sub
                .Cells(Ro, Col).Interior.ColorIndex = Cnt
                .Cells(Ro, Col + 1) = Cnt
            Next Ro
        Next Col
    End With
End Sub

回复

使用道具 举报

发表于 2009-12-3 14:21 | 显示全部楼层

QUOTE:
以下是引用amulee在2009-12-3 14:18:00的发言:

这个思路和我一样

[em01]

嘻嘻,咱俩心有灵犀嘛

[em02][em02]
回复

使用道具 举报

发表于 2009-12-3 14:24 | 显示全部楼层

QUOTE:
以下是引用大灰狼在2009-12-3 14:21:00的发言:

嘻嘻,咱俩心有灵犀嘛

[em02][em02]

[em06][em06][em06]
回复

使用道具 举报

发表于 2009-12-3 14:25 | 显示全部楼层

QUOTE:
以下是引用amulee在2009-12-3 14:24:00的发言:

[em06][em06][em06]

[em07][em31][em32]
回复

使用道具 举报

发表于 2009-12-3 14:28 | 显示全部楼层

阿木的办法,排除了mod,就是先取行列的范围,然后在其中循环。很高的哦。

c = Int(i / (x + 0.01)) * (y + 2) + 1

思路是这样的,比如x是10,那么1-10就是第一列。i/10,如果i=10,那么int(i/10)就是1了。我现在要1-10的除以10以后全不满1,所以是i/(10+0.01).

回复

使用道具 举报

发表于 2009-12-3 14:29 | 显示全部楼层

QUOTE:
以下是引用大灰狼在2009-12-3 14:25:00的发言:

[em07][em31][em32]

2006-8-30 11:16:00注册?帖子总数8 篇!!!

你真是超级潜水员啊。

才发现都不大来。。。。。

回复

使用道具 举报

发表于 2009-12-3 14:30 | 显示全部楼层

QUOTE:
以下是引用amulee在2009-12-3 14:29:00的发言:

2006-8-30 11:16:00注册?帖子总数8 篇!!!

你真是超级潜水员啊。

才发现都不大来。。。。。

嘻嘻嘻,我是追随小红帽来的,小红帽冒泡,我才冒出来,小红帽不冒泡,我陪她一起潜水

[em04]
回复

使用道具 举报

 楼主| 发表于 2009-12-3 14:51 | 显示全部楼层

明白了自己的方法,

现在这么多好方法,

让我一直深度迷糊中 ... 先学习[em04]

谢谢来自海底的大灰狼!

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-26 05:07 , Processed in 0.400625 second(s), 8 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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