请问这样的特殊字符串排序如何排

最初的字符串列表

['A', 'A+', 'A-', 'AA', 'AA+', 'AA-', 'AAA', 'B', 'B-', 'BB', 'BB+', 'BBB', 'BBB+', 'BBB-', 'C', 'CC', 'CCC']

最终要求的结果

['A', 'A+', 'A-', 'AA', 'AA+', 'AA-', 'AAA', 'B', 'B-', 'BB', 'BB+', 'BBB', 'BBB+', 'BBB-', 'C', 'CC', 'CCC']

 

排序规则

1. A>B>C

2. AA+ > AA > AA- (这里的+-是我的问题根源所在)

 

目前有一个这样的逻辑,自己有点糊涂了,得到的结果和最终要求不一样

from functools import cmp_to_key


def cmp(s1, s2):
    list1 = list(s1)
    list2 = list(s2)
    # sort_dict = {"+": -1, "-": -2}
    sort_dict = {"-": 1}
    while list1 and list2:
        value1 = list1.pop(0)
        if sort_dict.get(value1):
            value1 = sort_dict.get(value1)
        value2 = list2.pop(0)
        if sort_dict.get(value2):
            value2 = sort_dict.get(value2)
        if isinstance(value1, str):
            value1 = ord(value1)
        if isinstance(value2, str):
            value2 = ord(value2)
        if value1 == value2:
            continue
        elif value1 > value2:
            return -1
        else:
            return 1
    if list1:
        return -1
    else:
        return 1


str_list = ['A', 'A+', 'A-', 'AA', 'AA+', 'AA-', 'AAA', 'B', 'B-', 'BB', 'BB+', 'BBB', 'BBB+', 'BBB-', 'C', 'CC', 'CCC']

str_list.sort(key=cmp_to_key(cmp), reverse=True)

有哪位朋友帮忙指点一二,如果您有更好的方法,麻烦您帮忙解答一下,非常感谢~~~~

 

la = ['A', 'A+', 'A-', 'AA', 'AA+', 'AA-', 'AAA', 'B', 'B-', 'BB', 'BB+', 'BBB', 'BBB+', 'BBB-', 'C', 'CC', 'CCC']
def df(v):
    if v[-1]=="+":
        s = v[:-1]
        n = -1
    elif v[-1]=="-":
        s = v[:-1]
        n = 1
    else:
        s = v
        n = 0
    return (s,n)
la.sort(key=df)
print(la)

结果

['A+', 'A', 'A-', 'AA+', 'AA', 'AA-', 'AAA', 'B', 'B-', 'BB+', 'BB', 'BBB+', 'BBB', 'BBB-', 'C', 'CC', 'CCC']  

la = ['A', 'A+', 'A-', 'AA', 'AA+', 'AA-', 'AAA', 'B', 'B-', 'BB', 'BB+', 'BBB', 'BBB+', 'BBB-', 'C', 'CC', 'CCC']
def df(v):
    se = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
    mak = str.maketrans(se,se[::-1])
    v = v.translate(mak)
    if v[-1]=="+":
        s = v[:-1]
        n = 1
    elif v[-1]=="-":
        s = v[:-1]
        n = -1
    else:
        s = v
        n = 0
    return (s,n)
la.sort(key=df,reverse=True)
print(la)

 

最初的字符串列表和最终要求的结果是一样的,没能看懂题目的意思

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y