1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        Python輕量級循環(huán)-列表推導式

        共 1776字,需瀏覽 4分鐘

         ·

        2021-01-23 13:57

        '+j for i in girls for j in boys if i[0]==j[0]]"],[20,"\n","24:\"0WUn\"|36:131"],[20,"['alice<->arnold', 'bernice<->bob', 'bernice<->bernod', 'clarice<->chris']"],[20,"\n","24:\"LIYq\"|36:131"],[20,"\n","24:\"nuKS\"|32:1"],[20,"多循環(huán)+多條件"],[20,"\n","24:\"JNiT\"|32:1"],[20,"第一個字母+第二個字母均相同"],[20,"\n","24:\"AnHr\""],[20,"[i+'<->'+j for i in girls for j in boys if (i[0]==j[0] and i[1]==j[1])]"],[20,"\n","24:\"8YIq\"|36:131"],[20,"?['bernice<->bernod']"],[20,"\n","24:\"Wz6V\"|36:131"],[20,"\n","24:\"eXEM\"|32:1"],[20,"元組循環(huán)"],[20,"\n","24:\"mumJ\"|32:1"],[20,"列表可以直接循環(huán),改成元組也是可以的,但是直接生產(chǎn)了迭代器"],[20,"\n","24:\"CjHw\""],[20,"(i+'<->'+j for i in girls for j in boys if i[0]==j[0])"],[20,"\n","24:\"ibSI\"|36:131"],[20,"at 0x0000015413B781C8>"],[20,"\n","24:\"vJU3\"|36:131"],[20,"\n","24:\"bneG\"|36:131"],[20,"tuples = (i+'<->'+j for i in girls for j in boys if i[0]==j[0])"],[20,"\n","24:\"7SCB\"|36:131"],[20,"for t in tuples:"],[20,"\n","24:\"cPWb\"|36:131"],[20,"? ? print(t)"],[20,"\n","24:\"t6o6\"|36:131"],[20,"alice<->arnold"],[20,"\n","24:\"mmCv\"|36:131"],[20,"bernice<->bob"],[20,"\n","24:\"DSuE\"|36:131"],[20,"bernice<->bernod"],[20,"\n","24:\"j7LD\"|36:131"],[20,"clarice<->chris"],[20,"\n","24:\"pBR7\"|36:131"],[20,"\n","24:\"81km\"|32:1"],[20,"效率問題"],[20,"\n","24:\"sOEF\"|32:1"],[20,"男孩-女孩名字對的例子中,其實效率不是很高,因為程序會檢測每個可能的配對。Python中有很多解決這個問題的方法,下面是其中一種比較高效的方法。"],[20,"\n","24:\"Xv2b\""],[20,"letterGirls = {}"],[20,"\n","24:\"7dmT\"|36:131"],[20,"for girl in girls:"],[20,"\n","24:\"ST3E\"|36:131"],[20,"? ? letterGirls.setdefault(girl[0],[]).append(girl)"],[20,"\n","24:\"zzB6\"|36:131"],[20,"print([i+'<->'+j for?j in boys? for i in letterGirls[j[0]]])"],[20,"\n","24:\"sn8L\"|36:131"],[20,"['clarice<->chris', 'alice<->arnold', 'bernice<->bob', 'bernice<->bernod']"],[20,"\n","24:\"5qCv\"|36:131"],[20,"看看我們構(gòu)建的字典長啥樣"],[20,"\n","24:\"t6WC\""],[20,"letterGirls"],[20,"\n","24:\"HSNh\"|36:131"],[20,"{'a': ['alice'], 'b': ['bernice'], 'c': ['clarice']}"],[20,"\n","24:\"v1e3\"|36:131"],[20,"注意:","8:1"],[20,"setdefault()方法,是字典的一個方法,類似于get()方法,如果鍵不存在于字典中,將會添加鍵并將值設(shè)為默認值。如果存在,則返回該字段的值。","0:\"%23000000\"|31:2"],[20,"語法:dict.setdefault(key, default=None)"],[20,"\n","24:\"INBu\"|linespacing:\"115\""]]">

        概 ?述

        Python 列表推導式(list comprehension)利用其他列表創(chuàng)建新的列表,工作方式類似于for循環(huán),使用列表推導式可以快速生成一個列表,或者根據(jù)某個列表生成滿足指定需求的列表。


        單循環(huán)

        [i for i in range(10)][0,?1,?2,?3,?4,?5,?6,?7,?8,?9]


        單循環(huán)+條件

        0-20中所有能被3整除的數(shù)是多少

        [i for i in range(20) if i%3==0][0, 3, 6, 9, 12, 15, 18]

        ?

        多循環(huán)-2次

        'ABC'和'EGF'所有可能的兩兩組合

        [i+j for i in 'ABC' for j in 'EFG']['AE',?'AF',?'AG',?'BE',?'BF',?'BG',?'CE',?'CF',?'CG']


        多循環(huán)-3次

        'ABC'、'EFG'、‘HIJ’所有可能的三三組合

        [i+j+u for i in 'ABC' for j in 'EFG' for u in 'HIJ']['AEH', 'AEI', 'AEJ', 'AFH', 'AFI', 'AFJ', 'AGH', 'AGI', 'AGJ', 'BEH', 'BEI', 'BEJ', 'BFH', 'BFI', 'BFJ', 'BGH', 'BGI', 'BGJ',?'CEH',?'CEI',?'CEJ',?'CFH',?'CFI',?'CFJ',?'CGH',?'CGI',?'CGJ']



        多循環(huán)+單條件

        首字母相同的男孩 女孩組合

        girls = ['alice','bernice','clarice']boys  = ['chris','arnold','bob','bernod'][i+'<->'+j for i in girls for j in boys if i[0]==j[0]]['alice<->arnold', 'bernice<->bob', 'bernice<->bernod', 'clarice<->chris']

        ?

        多循環(huán)+多條件

        第一個字母+第二個字母均相同

        [i+'<->'+j for i in girls for j in boys if (i[0]==j[0] and i[1]==j[1])]?['bernice<->bernod']



        元組循環(huán)

        列表可以直接循環(huán),改成元組也是可以的,但是直接生產(chǎn)了迭代器

        (i+'<->'+j for i in girls for j in boys if i[0]==j[0]) at 0x0000015413B781C8>
        tuples = (i+'<->'+j for i in girls for j in boys if i[0]==j[0])for t in tuples: print(t)alice<->arnoldbernice<->bobbernice<->bernodclarice<->chris



        效率問題

        男孩-女孩名字對的例子中,其實效率不是很高,因為程序會檢測每個可能的配對。Python中有很多解決這個問題的方法,下面是其中一種比較高效的方法。

        letterGirls = {}for girl in girls:    letterGirls.setdefault(girl[0],[]).append(girl)print([i+'<->'+j for j in boys  for i in letterGirls[j[0]]])['clarice<->chris', 'alice<->arnold', 'bernice<->bob', 'bernice<->bernod']

        看看我們構(gòu)建的字典長啥樣

        letterGirls{'a': ['alice'], 'b': ['bernice'], 'c': ['clarice']}

        注意:setdefault()方法,是字典的一個方法,類似于get()方法,如果鍵不存在于字典中,將會添加鍵并將值設(shè)為默認值。如果存在,則返回該字段的值。語法:dict.setdefault(key, default=None)



        學習交流群

        發(fā)現(xiàn)“在看”和“贊”了嗎,戳我試試吧
        瀏覽 74
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            午夜精品一区二区三区在线视频99 | 欧美丰满熟妇BBBBBB禁忌 | 91麻豆精品一区二区三区 | 久久久久国产精品视频 | 三级视频网站在线观看 | 动漫美女被到爽视频 | 久久久久国产精 | 国产熟妇毛多 久久久久一区 | 香蕉色网 | 我要操逼网 |