一个可自动生成行排号的excel VBA小工具

如下图,点击“生成行排号”按钮即可生成想要的行排号

基本用法如下:

1、设置顺序排列的行排号(每排的行号一致,行的方向排序方向也一致)

2、设置顺序排列的行排号(行号从小到大排列,而不受排的限制)

3、设置之字排序的行排号(每排的行号一致,行的方向排序方向相反)

4、设置之字排序的行排号(行号从小到大排列,而奇偶排行的方向排序方向相反)

5、其他注意事项:

(1)排步长设置,只能是1或-1,即不能进行跳排的设置,当为1时排的排列是顺序,为-1时排列为倒序。

(2)行步长设置,可以设置为任意整数i。

(3)可以进行多种行排号的设置,依次列出,即可一次性生成所有行排号。

在最后把原始代码奉上,愿有兴趣的小伙伴可以继续优化设计:

Sub 生成行排号()

'对变量进行定义
'c为列数,r为行数
'order_1为起始排序方式,order_2为排列方式
'start_row为起始行号,start_col为起始排号,b为是否需要越排计行
Dim c As Integer, r As Integer
Dim order_1 As String
Dim start_row As Integer, start_col As Integer, step_row As Integer, step_col As Integer
Dim b As String

'其他变量为临时性变量
Dim rng As Range
Dim num As Integer, num_1 As Integer, num_2 As Integer
Dim i As Integer, j As Integer, l As Integer, m As Integer


Application.ScreenUpdating = False                   '关闭屏幕刷新

Set rng = Range(Worksheets("行排号设置").Range("A1"), Cells(Worksheets("行排号设置").Range("A10000").End(xlUp).Row, 8))


If rng.Rows.Count > 1 Then               '判断A列有无录入数据
    Range("L:M").Clear                   '清空M列和N列
    Range("L1").Value = "排号"           '生成表头——排号
    Range("M1").Value = "行号"           '生成表头——行号
    For num = 2 To rng.Rows.Count        '对录入的数据进行遍历
        '将参数数据提供给变量
        c = rng(num, 1).Value
        r = rng(num, 2).Value
        start_col = rng(num, 3).Value
        start_row = rng(num, 4).Value
        step_col = rng(num, 5).Value
        step_row = rng(num, 6).Value
        order_1 = rng(num, 7).Value
        b = rng(num, 8).Value
        
        If order_1 = "顺序排列" Then
            If b = "是" Then                   '当行号跨排统计时
                l = Worksheets("行排号设置").Range("L100000").End(xlUp).Row + 1
                m = Worksheets("行排号设置").Range("M100000").End(xlUp).Row + 1
                For num_1 = start_col To (start_col + c - 1) Step step_col
                    For j = 1 To r
                        Range("L" & l).Value = num_1
                        l = l + 1
                    Next
                Next
                
                For num_2 = start_row To start_row + (c * r - 1) * step_row Step step_row
                    Range("M" & m).Value = num_2
                    m = m + 1
                Next
            Else                               '当行号不跨排统计时
                l = Worksheets("行排号设置").Range("L100000").End(xlUp).Row + 1
                m = Worksheets("行排号设置").Range("M100000").End(xlUp).Row + 1
                For num_1 = start_col To (start_col + c - 1) Step step_col
                    For num_2 = start_row To (r + start_row - 1) * step_row Step step_row
                        Range("L" & l).Value = num_1
                        l = l + 1
                        Range("M" & m).Value = num_2
                        m = m + 1
                    Next
                Next
            End If
        Else
            If b = "是" Then                   '当行号跨排统计时
                l = Worksheets("行排号设置").Range("L100000").End(xlUp).Row + 1
                m = Worksheets("行排号设置").Range("M100000").End(xlUp).Row + 1
                For num_1 = start_col To (start_col + c - 1) Step step_col
                    For j = 1 To r
                        Range("L" & l).Value = num_1
                        l = l + 1
                    Next
                Next
                '定义起始排顺序,次排倒序,以此类推
                '用i对排进行计数,i为奇数时顺序,i为偶数时倒序
                i = 1
                For num_1 = start_col To (start_col + c - 1) Step step_col
                    If i Mod 2 Then
                        For num_2 = start_row + ((i - 1) * r) * step_row To start_row + (i * r - 1) * step_row Step step_row
                            Range("M" & m).Value = num_2
                            m = m + 1
                        Next
                    Else
                        For num_2 = start_row + (i * r - 1) * step_row To start_row + ((i - 1) * r) * step_row Step -1 * step_row
                            Range("M" & m).Value = num_2
                            m = m + 1
                        Next
                    End If
                    i = i + 1
                Next
            Else                               '当行号不跨排统计时
                l = Worksheets("行排号设置").Range("L100000").End(xlUp).Row + 1
                m = Worksheets("行排号设置").Range("M100000").End(xlUp).Row + 1
                i = 1
                For num_1 = start_col To (start_col + c - 1) Step step_col
                    '定义起始排顺序,次排倒序,以此类推
                    '用i对排进行计数,i为奇数时顺序,i为偶数时倒序
                    If i Mod 2 Then
                        For num_2 = start_row To (r + start_row - 1) * step_row Step step_row
                            Range("L" & l).Value = num_1
                            l = l + 1
                            Range("M" & m).Value = num_2
                            m = m + 1
                        Next
                    Else
                        For num_2 = (r + start_row - 1) * step_row To start_row Step -1 * step_row
                            Range("L" & l).Value = num_1
                            l = l + 1
                            Range("M" & m).Value = num_2
                            m = m + 1
                        Next
                    End If
                    
                    i = i + 1
                Next
            End If
            
        End If
    Next
Else
    MsgBox "无数据"
End If

Application.ScreenUpdating = True          '重新打开屏幕刷新

End Sub

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/631059.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

UEC++学习(十五)创建、查找、加入会话

创建会话 基于上篇配置steam在线子系统之后&#xff0c;在Character.h中声明一个会话创建完成时的委托以及回调函数。 #include "Interfaces/OnlineSessionInterface.h"public://指向在线会话界面的指针,将会话接口存储在里面TSharedPtr<class IOnlineSession, ES…

电脑缺失api-ms-win-crt-runtime-l1-1-0.dll文件的几种修复方法

当您在使用电脑过程中遇到程序启动失败&#xff0c;提示缺少“api-ms-win-crt-runtime-l1-1-0.dll”文件时&#xff0c;不必过于焦虑&#xff0c;此问题通常与Windows系统的Visual C Redistributable组件未正确安装或损坏有关。小编将介绍5种修复电脑缺失api-ms-win-crt-runtim…

STM32-09-IWDG

文章目录 STM32 IWDG1. IWDG2. IWDG框图3. IWDG寄存器4. IWDG寄存器操作步骤5. IWDG溢出时间计算6. IWDG配置步骤7. 代码实现 STM32 IWDG 1. IWDG IWDG Independent watchdog&#xff0c;即独立看门狗&#xff0c;本质上是一个定时器&#xff0c;这个定时器有一个输出端&#…

elementui 那些遇到的问题呀

1、在父组件调用子组件方法的&#xff0c;现在想关闭el-dialog 弹框&#xff0c;清除编辑器里面的值&#xff0c;结果哦方法走了但是没清空&#xff0c;原代码是这样的 父组件&#xff1a;<el-dialog closed"formulaclosed" v-model"detailsFormVisible&quo…

颜色的表示和还原(一)

这篇文章主要提炼于ICCV 2019 Tutorial: Understanding Color and the In-Camera Image Processing Pipeline for Computer Vision。里面深入浅出地讲解了很多ISP中的基础知识&#xff0c;这里主要对颜色相关的部分做一点总结。 假设不成立了 相机经常被简单地看作是衡量光线…

2022 年高教社杯全国大学生数学建模竞赛-C 题 古代玻璃制品的成分分析与鉴别详解+聚类模型Python代码源码

前言 简单介绍一下我自己&#xff1a;博主专注建模四年&#xff0c;参与过大大小小数十来次数学建模&#xff0c;理解各类模型原理以及每种模型的建模流程和各类题目分析方法。参与过十余次数学建模大赛&#xff0c;三次美赛获得过二次M奖一次H奖&#xff0c;国赛二等奖。**提…

设计模式:外观模式(Facade)

设计模式&#xff1a;外观模式&#xff08;Facade&#xff09; 设计模式&#xff1a;外观模式&#xff08;Facade&#xff09;模式动机模式定义模式结构时序图模式实现在单线程环境下的测试在多线程环境下的测试模式分析优缺点适用场景应用场景模式扩展参考 设计模式&#xff1…

21【Aseprite 作图】画白菜

1 对着参考图画轮廓 2 缩小尺寸 变成这样 3 本来是红色的描边&#xff0c;可以通过油漆桶工具&#xff08;取消 “连续”&#xff09;&#xff0c;就把红色的轮廓线&#xff0c;变成黑色的 同时用吸管工具&#xff0c;吸取绿色和白色&#xff0c;用油漆桶填充颜色 4 加上阴影…

TypeScript高级类型 在鸿蒙中的使用 Partial、Required、Readonly、Pick、Record

我的工程代码在这里&#xff0c;持续更新中 欢迎交流&#xff0c;谢谢 https://github.com/MartinLi89/WanHarmony Partial <Type> 新定义 一个类型&#xff0c;将所有属性变为可选的类. class TextTS {a: string "1"b: string "2"c: string &…

05-应用级开发者 AI 时代破局点

后端应用级开发者该如何拥抱 AI GC&#xff1f;就是在这样的一个大的浪潮下&#xff0c;我们的传统的应用级开发者。我们该如何选择职业或者是如何去快速转型&#xff0c;跟上这样的一个行业的一个浪潮? 0 AI金字塔模型 越往上它的整个难度就是职业机会也好&#xff0c;或者说…

Mysql-几何类型-POINT

在MySQL中&#xff0c;地理空间数据类型和功能被称为GIS&#xff08;Geographic Information System&#xff0c;地理信息系统&#xff09;。MySQL支持几种不同的空间数据类型&#xff0c;包括点&#xff08;POINT&#xff09;、线&#xff08;LINESTRING&#xff09;、多边形&…

Python 提取PDF表格数据并保存到TXT文本或Excel文件

目录 安装Python库 Python提取PDF表格数据并保存到文本文档 Python提取PDF表格数据并保存到Excel文档 PDF文件常用于存储和共享各种类型的文档&#xff0c;这些文档可能包括大量的数据表格。通过提取这些PDF表格数据&#xff0c;我们可以将其导入到Excel、数据库或统计软件等…

使用Docker进行Jmeter分布式搭建

大家好&#xff0c;随着技术的不断发展&#xff0c;对性能测试的要求也日益提高。在这样的背景下&#xff0c;如何利用 Docker 来巧妙地搭建 Jmeter 分布式成为了关键所在。现在&#xff0c;就让我们开启这场探索之旅&#xff0c;揭开其神秘的面纱。前段时间给大家分享了关于 L…

如何组织 Vue 项目

介绍 在启动 Vue 项目时&#xff0c;思考项目结构至关重要。主要考虑因素是预期项目的规模。在本篇博文中&#xff0c;我将探讨适用于不同规模 Vue 项目的各种结构。这个考虑与康威定律相吻合&#xff1a; “设计系统的组织受限于产生这些组织沟通结构的设计。” - 梅尔康威 基…

平均工资数据分析之回归

链接: R语言实战——中国职工平均工资的变化分析——相关与回归分析 1、模型诊断和评估的方法 1. 残差分析 1、残差图 (Residual Plot)&#xff1a;用于检查残差是否存在非随机模式。理想情况下&#xff0c;残差应随机分布在零附近。 2、Q-Q 图 (Quantile-Quantile Plot)&am…

redis-stack部署概要

第一步&#xff0c;下载redis-stack 下载链接&#xff1a;Downloads - Redis 第二步&#xff0c;redis安装包解压缩 gzip -d redis-stack-server-7.2.0-v10.rhel8.x86_64.tar.gz tar -xvf redis-stack-server-7.2.0-v10.rhel8.x86_64.tar 第三步&#xff0c;编辑etc下的redis…

高性能日志库go-logger2.0.4—支持slog日志文件切割

go-logger v2.0.4 发布 该版本主要支持go原生日志库 log/slog 的日志文件切割&#xff0c;压缩等功能。 log/slog 库是 Go 语言用于结构化日志记录的一个强大工具&#xff0c;它旨在提升日志的管理和分析能力&#xff0c;同时保证代码的简洁性和执行效率。随着 Go 语言生态的…

简单聊聊分布式和集群

前言 分布式和集群&#xff0c;我们都听的比较多&#xff0c;分布式系统和集群的概念对于刚进入职场的小伙伴可能不是很清楚&#xff0c;这篇文章我们就一起看看两者到底是什么&#xff0c;有什么区别。 什么是分布式系统&#xff1f; 先看下书面解释&#xff1a; 分布式系统…

学习笔记-C++

目录 1、何为常量 2、关键字 3、实型 4、水平制表符 5、string字符串 6、C中的三目运算符 7、随机数种子 8、结构体 9、各的区 10、引用 11、函数默认参数 12、函数占位参数 13、函数重载 14、私有属性 15、让另一个类作为本类的成员 16、声明和实现的文件…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-15.7讲 GPIO中断实验-编写按键中断驱动

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…