Python 演習-3

(1) 以下の 2 文字未満の名前を削除し、スペルが異なる同じ名前を結合し、大文字で出力します。

names=['Bob','JOHN','alice','bob','ALICE','J','Bob']
name_replace={name.title() for name in names if len(name)>2}
print(name_replace)

(2) 上のリストにある同姓同名の人物をすべて数えて、辞書形式で表現します。必要な出力形式は次のとおりです。

{'ボブ': 3、'ジョン': 1、'アリス': 2}

names =['Bob','JOHN','alice','bob','ALICE','J','Bob']
name_replace =[name.title() for name in names if len(name)>2]
real_name={name:name_replace.count(name) for name in name_replace}
print(real_name)

(3) 2 つの方法を使用して、以下のリストから重複する要素を削除します。

a_list=[1,1,2,3,4,5,6,7,6,5,4,3,3,5,2]

# 方法一
a_list=[1,1,2,3,4,5,6,7,6,5,4,3,3,5,2]
a_dic={key:0 for key in a_list}
new_dict=a_dic.keys()
print(new_dict)
 
# 方法二
a_list=[1,1,2,3,4,5,6,7,6,5,4,3,3,5,2]
new_dict=list(set(a_list))
print(new_dict)

(4) 次の 2 つのリストについて、要素が異なる場合は、各ペアをタプルにカプセル化し、そのようなステップレス パッケージをすべてリストにパックすると、期待される結果は次のようになります。

list_a=[1,2,3]

list_b=[2,7]

[(1, 2)、(1, 7)、(2, 7)、(3, 2)、(3, 7)]

list_a=[1,2,3]
list_b=[2,7]
new_list=[(x,y) for x in list_a for y in list_b if x!=y]
print(new_list)

(5) 文字列内のスペースをすべて削除します。

s = " sfafas asfasf afasf saf asfasf a asf asa"

s = " sfafas asfasf afasf saf asfasf a asf asa"
s1=s.replace(" ","")
print(s1)

(6)

文字列内の中国語の文字数を取得します。

str01 = "これは素晴らしい物語の起源です: abcdefasfas,123123124,here,asfasf,123,start"

str01 = "这是一个美好的故事起源:abcdefasfas,123123124,在这里的,asfasf,123,开始"
count = 0
for i in str01:
    if 0x4E00 <= ord(i) <= 0x9FA5:
        count += 1
 
print(f"字符串中的中文有{count}个")

(7) 文字列内の各文字が別の文字列に出現することを確認する方法


def is_in(full_str, sub_str):
    try:
        full_str.index(sub_str)
        return True
    except ValueError:
        return False
 
print(is_in("hello, python", "llo"))  
print(is_in("hello, python", "lol"))  
 
# 使用 in 和 not in
print("llo" in "hello, python") 
print("lol" in "hello, python")
 
# 使用 find
print("hello, python".find("llo") != -1)   
print("hello, python".find("lol") != -1)   

おすすめ

転載: blog.csdn.net/weixin_68479946/article/details/128842317