您的位置 首页 Python

python – Django中的Slugify字符串

我开发了一个表单,用户添加了他/她的名字和姓氏.

对于用户名(唯一属性),我设计了以下方法:

名字:harrY姓氏:PottEr – >用户名:Harry-Potter

名字:HARRY姓氏:POTTER – >用户名:Harry-Potter-1

名字:harrY姓氏:PottEr – >用户名:Harry-Potter-2

等等..

这是我的函数定义:

def return_slug(firstname,lastname):
    u_username = firstname.title()+'-'+lastname.title()         //Step 1
    u_username = '-'.join(u_username.split())                     //Step 2
    count = User.objects.filter(username=u_username).count()    //Step 3
    if count==0:
        return (u_username)
    else:
        return (u_username+'-%s' % count)

我无法弄清楚在执行第3步之前要做什么.我应该把[:len(u_username)]放在哪里比较字符串?

编辑:

如果存在多个Harry-Potter实例,则通过解决最后添加整数的问题来应用此方法.我的问题是:我将如何检查附加到Harry-Potter的最后一个整数是多少.

解决方法

试试这个:

from django.utils.text import slugify

def return_slug(firstname,lastname):

    # get a slug of the firstname and last name.
    # it will normalize the string and add dashes for spaces
    # i.e. 'HaRrY POTTer' -> 'harry-potter'
    u_username = slugify(unicode('%s %s' % (firstname,lastname)))

    # split the username by the dashes,capitalize each part and re-combine
    # 'harry-potter' -> 'Harry-Potter'
    u_username = '-'.join([x.capitalize() for x in u_username.split('-')])

    # count the number of users that start with the username
    count = User.objects.filter(username__startswith=u_username).count()
    if count == 0:
        return u_username
    else:
        return '%s-%d' % (u_username,count)

关于作者: dawei

【声明】:金华站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

热门文章