首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

AHK:从列表中去掉重复项,并在各自的列表项中添加重复计数

AHK是指AutoHotkey,它是一种自动化脚本语言,用于自动化任务和快速键盘宏编写。在处理列表时,如果需要去掉重复项并在各自的列表项中添加重复计数,可以使用以下方法:

  1. 创建一个空的新列表。
  2. 遍历原始列表中的每个元素。
  3. 对于每个元素,检查它是否已经存在于新列表中。
  4. 如果不存在,将该元素添加到新列表中,并在该元素后面添加重复计数。
  5. 如果存在,增加该元素的重复计数。
  6. 最后,返回新列表作为结果。

以下是一个示例的AutoHotkey代码,实现了上述功能:

代码语言:txt
复制
originalList := ["A", "B", "C", "A", "B", "D", "E", "E", "E"]
newList := []

Loop, % originalList.MaxIndex()
{
    currentItem := originalList[A_Index]
    if (!IsInList(currentItem, newList))
    {
        count := CountOccurrences(currentItem, originalList)
        newItem := currentItem . " (" . count . ")"
        newList.Push(newItem)
    }
}

MsgBox % newList.Join(", ")

IsInList(item, list)
{
    for index, value in list
    {
        if (value = item)
            return true
    }
    return false
}

CountOccurrences(item, list)
{
    count := 0
    for index, value in list
    {
        if (value = item)
            count++
    }
    return count
}

在这个示例中,原始列表originalList包含了一些重复的元素。通过遍历原始列表并使用IsInList函数检查元素是否已经存在于新列表中,然后使用CountOccurrences函数计算元素的重复次数,并将新的带有重复计数的元素添加到新列表newList中。最后,使用Join函数将新列表中的元素连接成一个字符串,并通过MsgBox函数显示出来。

请注意,这只是一个示例代码,你可以根据实际需求进行修改和优化。另外,腾讯云并没有针对AHK提供特定的产品或服务,因此无法提供相关的产品介绍链接地址。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 变量类型-List

    教程: 一:列表的创建     List(列表) 是 Python 中使用最频繁的数据类型。列表中元素的类型可以不相同,数字,字符串甚至可以包含列表(所谓嵌套)     (1)List写在方括号之间,元素用逗号隔开     (2)和字符串一样,list可以被索引和切片     (3)List中的元素是可以改变的 二:列表的索引     变量[头标:尾标]     从前到后:0---end     从后到前:-1---->-len(str)     list.index("s") 三:列表的更新     对列表中的数据项进行修改或者更新     使用append()方法来添加列表项 四:列表项的删除     del     remove 五:列表操作符     +     用于组合列表     *       用于重复列表     in 、not in 六:列表函数     len,max,min,-----list()     list.append()末尾添加项     list.index('')末尾添加项     list.pop()删除列表项     list.clear()等等     list.reverse()元素翻转     list.sort()对列表进行排序 七:多维列表的创建及访问方式     matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]     matrix[1][2]     Out[2]: 6 八:列表和字符串的相互转化     str.split(sep=None, maxsplit = -1)    将字符串分各成列表     sep指定分隔符     maxsplite分割成的数量 九:"sep".join(list)      可以是split的逆运算     S.jion(iterable)    --->str        列表转换为字符串     sep = separator    分隔器 IS S     example:     "."join(list)    用.连接字符串

    03

    python的dict,set,list

    字典(dict) dict 用 {} 包围  dict.keys(),dict.values(),dict.items()  hash(obj)返回obj的哈希值,如果返回表示可以作为dict的key  del 或 dict.pop可以删除一个item,clear清除所有的内容  sorted(dict)可以吧dict排序  dict.get()可以查找没存在的key,dict.[]不可以  dict.setdefault() 检查字典中是否含有某键。 如果字典中这个键存在,你可以取到它的值。 如果所找的键在字典中不存在,你可以给这个键赋默认值并返回此值。  {}.fromkeys()创建一个dict,例如: {}.fromkeys(('love', 'honor'), True) =>{'love': True, 'honor': True}  不允许一个键对应多个值  键值必须是哈希的,用hash()测试  一个对象,如果实现_hash()_方法可以作为键值使用

    01

    C#学习笔记—— 常用控件说明及其属性、事件

    1、 窗体 的属性 1、常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体。 (2) WindowState属性: 用来获取或设置窗体的窗口状态。 取值有三种: Normal (窗体正常显示)、 Minimized(窗体以最小化形式显示)和 Maximized(窗体以最大化形式显示)。 (3)StartPosition属性:用来获取或设置运行时窗体的起始位置。其取值及含义如表9-1 所示。默认的起始位置是WindowsDefaultLocation。 (4)Text属性:该属性是一个字符串属性,用来设置或返回在窗口标题栏中显示的文字。 (5)Width属性:用来获取或设置窗体的宽度。 (6)Height属性:用来获取或设置窗体的高度。 (7)Left属性:用来获取或设置窗体的左边缘的x坐标(以像素为单位)。 (8)Top属性:用来获取或设置窗体的上边缘的y坐标(以像素为单位)。 (9)ControlBox属性:用来获取或设置一个值,该值指示在该窗体的标题栏中是否显示控制框。值为true时将显示控制框,值为false时不显示控制框。 (10)MaximizeBox属性:用来获取或设置一个值,该值指示是否在窗体的标题栏中显示最大化按钮。值为 true时显示最大化按钮,值为false时不显示最大化按钮。 (11)MinimizeBox 属性:用来获取或设置一个值,该值指示是否在窗体的标题栏中显示最小化按钮。值为 true时显示最小化按钮,值为false时不显示最小化按钮。 (12)AcceptButton 属性:该属性用来获取或设置一个值,该值是一个按钮的名称,当按 Enter 键时就相当于单击了窗体上的该按钮。 (13)CancelButton 属性:该属性用来获取或设置一个值,该值是一个按钮的名称,当按 Esc 键时就相当于单击了窗体上的该按钮。 (14)Modal 属性:该属性用来设置窗体是否为有模式显示窗体。如果有模式地显示该窗体,该属性值为true;否则为 false。当有模式地显示窗体时,只能对模式窗体上的对象进行输入。必须隐藏或关闭模式窗体(通常是响应某个用户操作),然后才能对另一窗体进行输入。有模式显示的窗体通常用做应用程序中的对话框。 (15)ActiveControl属性:用来获取或设置容器控件中的活动控件。窗体也是一种容器控件。 (16)ActiveMdiChild属性:用来获取多文档界面(MDI)的当前活动子窗口。 (17)AutoScroll 属性:用来获取或设置一个值,该值指示窗体是否实现自动滚动。如果此属性值设置为true,则当任何控件位于窗体工作区之外时,会在该窗体上显示滚动条。另外当自动滚动打开时,窗体的工作区自动滚动,以使具有输入焦点的控件可见。 (18)BackColor属性:用来获取或设置窗体的背景色。 (19)BackgroundImage属性:用来获取或设置窗体的背景图像。 (20)Enabled 属性:用来获取或设置一个值,该值指示控件是否可以对用户交互作出响应。如果控件可以对用户交互作出响应,则为 true;否则为false。默认值为true。 (21)Font属性:用来获取或设置控件显示的文本的字体。 (22)ForeColor属性:用来获取或设置控件的前景色。 (23)IsMdiChild属性:获取一个值,该值指示该窗体是否为多文档界面(MDI)子窗体。值为 true时,是子窗体,值为false时,不是子窗体。 (24)IsMdiContainer 属性:获取或设置一个值,该值指示窗体是否为多文档界面(MDI)中的子窗体的容器。值为true时,是子窗体的容器,值为false时,不是子窗体的容器。 (25)KeyPreview属性:用来获取或设置一个值,该值指示在将按键事件传递到具有焦点的控件前,窗体是否将接收该事件。值为true时,窗体将接收按键事件,值为false时,窗体不接收按键事件。 (26)MdiChildren属性:数组属性。数组中的每个元素表示以此窗体作为父级的多文档界面(MDI)子窗体。 (27)MdiParent属性:用来获取或设置此窗体的当前多文档界面(MDI)父窗体。 (28)ShowInTaskbar属性:用来获取或设置一个值,该值指示是否在Windows任务栏中显示窗体。 (29)Visible属性:用于获取或设置一个值,该值指示是否显示该窗体或控件。值为true 时显示窗体或控件,为 false时不显示。 (30)Capture属性:如果该属性值为true,则鼠标就会被限定只由此控件响应,不管鼠标是否在此控件的范围内。 2、常用的方法 下面介绍一些窗体的最常用方法。 (1)Show方法:该方法的作用是让窗体显示出来,其调用格式为: 窗体名.

    02

    Vue.js 学习笔记 - 虚拟列表(Virtual-Scroll-List)心得

    手上有个字幕编辑器的项目,因为长视频也许会有几千条字幕,所以字幕编辑器的列表中就会有几千条列表项。 但是如果将这几千条列表项全部渲染在 DOM 中,就会造成浏览器轻则卡顿,重则卡死,根本无法正常使用。 针对这种情况,我通过 Google 了解到可以通过虚拟列表技术来解决。 虚拟列表做的事情,就是按需渲染。只需要渲染当前视图需要显示的几个条目和即将滚动到的几个条目。在开发者工具中可以发现,DOM 中只存在这么几条列表项,当滚动的时候会替换这几项。所以大大节省了系统资源,提升了用户体验。 我在 GitHub 上找了几个基于Vue.js 的虚拟列表实现,最终找到了一个最合适的 vue-virtual-scroll-list ,并在项目中进行了使用。 我在闲暇之余研读了一下此项目的代码,发现实现方式比想象中还要简单。

    02
    领券