亲宝软件园·资讯

展开

Python递增函数

Moelimoe 人气:2

需求:

Python处理重名字符串,添加或递增数字字符串后缀

要灵活处理字符串问题,使用re模块最为方便下面是一个对带有下划线+数字的后缀字符串递增的方法

def increase_string_suffix(s, incr_num=1):
    """
    带数字后缀"_d"的字符串自增方法,"name_1" 自增1 --> "name_2"
    Example
    -----------------
    >>> s = "name_01"
    >>> increase_string_suffix(s, incr_num=2)
    'name_03'
    """
    suffix_searched = re.search(r"(_)(\d+)$", s)
    if suffix_searched:
        suffix_plus_1 = re.sub(
            r"(_)(\d+)$",
            lambda x: f"{x.group(1)}{str(int(x.group(2)) + incr_num).zfill(len(x.group(2)))}",
            s
        )
    else:
        suffix_plus_1 = f"{s}_1"
    return suffix_plus_1

例子在代码中可以直接运行注释的doc部分,参数s是要传入的字符串,incr_num是一次要增加的步数
代码中核心部分是re.sub方法,r"(_)(\d+)$"是匹配搜寻部分,()对匹配的部分进行分组,x.group(1)是()匹配到的"",x.group(2)是匹配到的数字部分,zfill往左边填0补上长度,例如01→02而不会是01→2

也可以写一个递减的,或是修改前缀的,

例如:

def increase_string_prefix(s, incr_num=1):
    """
    带数字前缀"d-"的字符串自增方法,"1-name" 自增1 --> "2-name"
    Example
    -----------------
    >>> s = "1-name"
    >>> increase_string_prefix(s, incr_num=1)
    '2-name'
    """
    prefix_searched = re.search(r"^(\d+)(-)", s)
    if prefix_searched:
        prefix_plus_1 = re.sub(
            r"^(\d+)(-)",
            lambda x: f"{str(int(x.groups()[0]) + incr_num).zfill(len(x.groups()[0]))}{x.groups()[1]}",
            s
        )
    else:
        prefix_plus_1 = f"1-{s}"
    return prefix_plus_1

对于更多的正则表达式使用方法,可以参考之前的这篇文章

加载全部内容

相关教程
猜你喜欢
用户评论