成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

六個(gè)Python編程最受用的內(nèi)置函數(shù)使用詳解

89542767 / 512人閱讀


  小編寫這篇文章的話,主要是給大家做出一個(gè)解答,解答一些Python常見問題,比如關(guān)于編程函數(shù)的一些問題,哪些函數(shù)編程是最受用的呢?下面就給大家詳細(xì)介紹一下。


  合理的使用Python這門工具,能夠大大的提高其工作效率,起到事半功倍的作用。


  1.Map函數(shù)


  map函數(shù)可以使用另外一個(gè)函數(shù)轉(zhuǎn)換整個(gè)可迭代對(duì)象的函數(shù),包括將字符串轉(zhuǎn)換為數(shù)字、數(shù)字的四舍五入等等。


  之所以使用map函數(shù)來完成這些事情可以節(jié)約內(nèi)存,使代碼的運(yùn)行速度提高,并且使用的代碼量比較少。


  比如這里需要將一個(gè)字符串的數(shù)組轉(zhuǎn)換成數(shù)字的數(shù)組的形式。


  使用傳統(tǒng)的方式來進(jìn)行解析的話,使用for循環(huán)的方式就需要好幾行的代碼才能完成。


  strings=['1','2','3','4']
  res=[]
  for str_ in strings:
  res.append(int(str_))
  print(res)
  #[1,2,3,4]


  使用map函數(shù)直接需要一行代碼就可以完成了。


  strings=['5','6','7','8']
  res_map=map(int,strings)
  print(list(res_map))
  #[5,6,7,8]

  使用map(int,strings),其中int是作為函數(shù)作為參數(shù)傳入的,而strings就是可以迭代的對(duì)象。


  這里再使用一個(gè)我們自己創(chuàng)建的函數(shù)來轉(zhuǎn)換可序列化的數(shù)據(jù)。


  初始化一個(gè)make_super函數(shù)用來將英文字符串轉(zhuǎn)換成'大寫'的字符串。


  def make_super(text):
  res_text=text.upper()
  return res_text
  words=['python','java','scala']
  words_res=list(map(make_super,words))
  print(words_res)
  #['PYTHON','JAVA','SCALA']


  使用map(make_super,words),其中make_super是作為函數(shù)傳入的,而words作為可序列化數(shù)據(jù)。


  2.Lamdba函數(shù)


  lambda函數(shù)用于創(chuàng)建匿名函數(shù),又被稱為lambda表達(dá)式。實(shí)際上它只是一個(gè)表達(dá)式的存在,如果在代碼編寫過程中需要實(shí)現(xiàn)簡(jiǎn)單的函數(shù)邏輯但是多帶帶寫一個(gè)函數(shù)又比較麻煩就可以使用lambda表達(dá)式只需要一行代碼就可以完成了。


  比如需要實(shí)現(xiàn)一個(gè)簡(jiǎn)單的加法計(jì)算,使用基本的函數(shù)來實(shí)現(xiàn)需要?jiǎng)?chuàng)建一個(gè)add_1函數(shù)。


  def add_1(a,b):
  return a+b
  print(add_1(5,2))


  而使用lambda表達(dá)式,一行代碼就可以直接完成了,可以像下面這樣寫。


  add_2=lambda a,b:a+b
  print(add_2(10,10))


  lambda a,b:a+b表示a,b是作為參數(shù),a+b是作為函數(shù)的運(yùn)算邏輯被執(zhí)行。


  3.Enumerate函數(shù)


  enumerate函數(shù)一般用于可序列化數(shù)據(jù)的處理上面,而python中的可序列化數(shù)據(jù)又比較多,重要性就可想而知了。


  可以使用該函數(shù)直接遍歷出一個(gè)可序列化數(shù)據(jù)的下標(biāo)索引以及對(duì)應(yīng)的數(shù)據(jù)。


  使用一個(gè)列表數(shù)據(jù)來進(jìn)行舉例說明。


 words=['java','python','scala']


  使用enumerate函數(shù)來執(zhí)行一下整個(gè)遍歷,最終返回一個(gè)新的列表。


  for index,data in enumerate(words):
  print(f'當(dāng)前索引:{index},當(dāng)前數(shù)據(jù):{data}')
  #當(dāng)前索引:0,當(dāng)前數(shù)據(jù):java
  #當(dāng)前索引:1,當(dāng)前數(shù)據(jù):python
  #當(dāng)前索引:2,當(dāng)前數(shù)據(jù):scala


  看到返回的結(jié)果中包含了索引、數(shù)據(jù),這樣便于數(shù)據(jù)的組織和統(tǒng)計(jì),因此,將該函數(shù)也列為比較常用的函數(shù)之一。


  4.Reduce函數(shù)


  reduce函數(shù)通常用于計(jì)算整個(gè)列表的邏輯運(yùn)算,也就是將一個(gè)函數(shù)的運(yùn)算可以添加到這個(gè)列表的每個(gè)元素上面。


  '''
  reduce(function,iterable[,initializer])
  '''


  比如需要計(jì)算一個(gè)列表中每個(gè)元素之間的相乘的結(jié)果,則可以這樣寫。


  from functools import reduce
  list_=[10,20,30,40]
  print(reduce(lambda a,b:a*b,list_))


  這里由于函數(shù)的邏輯運(yùn)算比較簡(jiǎn)單,所以使用了lambda表達(dá)式表示兩個(gè)元素相乘。


  最終再使用reduce函數(shù),它的效果相當(dāng)于10*20*30*40,結(jié)果就是240000,和我們預(yù)想得到的計(jì)算結(jié)果是一致的。


  5.Filter函數(shù)


  filter函數(shù),從字面意思就可以看出它是過濾的意思,使用該函數(shù)可以有效的過濾掉不需要的列表中的數(shù)據(jù)元素。


  '''
  filter(function,iterable)
  '''


  在邏輯處理中,同樣是需要一個(gè)處理函數(shù)和一個(gè)可序列化的數(shù)據(jù)。


  nums=[1,2,3,4,5,6,7,8,9,20]
  nums_new=filter(lambda m:m%2==0,nums)
  print(list(nums_new))
  #[2,4,6,8,20]


  這里我們成功過濾掉了所有的奇數(shù)數(shù)據(jù)元素,最終只留下了偶數(shù)元素。


  6.Zip函數(shù)


  zip函數(shù)在多個(gè)列表的組裝過程中用到非常的多,可以同時(shí)遍歷多個(gè)列表并將相同位置的元素組合成一個(gè)元祖。


  list_res=[]
  for n in zip([1,2,3,4,5],['python','java','scala','c++','C#']):
  list_res.append(n)
  print(list_res)
  #[(1,'python'),(2,'java'),(3,'scala'),(4,'c++'),(5,'C#')]


  使用zip函數(shù)時(shí),像這樣的數(shù)據(jù)組合就可以輕松的實(shí)現(xiàn)。


  通過觀察上述的這些操作發(fā)現(xiàn)基本上都是對(duì)可序列化的數(shù)據(jù)的相關(guān)操作,因?yàn)樵趐ython的編碼過程中大多數(shù)的數(shù)據(jù)處理相關(guān)的操作都是基于可序列化的數(shù)據(jù)的。


  綜上所述,關(guān)于Python編程受歡迎的內(nèi)置函數(shù)就為大家介紹到這里了。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/128000.html

相關(guān)文章

  • 提高 Python 運(yùn)行效率六個(gè)竅門

    摘要:使用或機(jī)器語言的外部功能包處理時(shí)間敏感任務(wù),可以有效提高應(yīng)用的運(yùn)行效率。關(guān)鍵在于,優(yōu)化循環(huán)方案是提高應(yīng)用程序運(yùn)行速度的上佳選擇。此外,關(guān)于交叉編譯是否為提高運(yùn)行效率的最佳方法還存在討論的空間。在使用交叉編譯器時(shí),記得確保它支持你所用的版本。 Python 是一門優(yōu)秀的語言,它能讓你在短時(shí)間內(nèi)通過極少量代碼就能完成許多操作。不僅如此,它還輕松支持多任務(wù)處理,比如多進(jìn)程。 不喜歡 Pyt...

    huhud 評(píng)論0 收藏0
  • Python零基礎(chǔ)到入門】Python基礎(chǔ)語法篇——基本數(shù)據(jù)類型【文末送書】

    摘要:布爾值布爾值和布爾代數(shù)的表示完全一致,一個(gè)布爾值只有兩種值的數(shù)據(jù)類型可以通過內(nèi)置的函數(shù)查詢,例如還可以用來判斷和的區(qū)別在于不會(huì)認(rèn)為子類是一種父類類型。會(huì)認(rèn)為子類是一種父類類型?;竟δ苁沁M(jìn)行成員關(guān)系測(cè)試和刪除重復(fù)元素。 ...

    Winer 評(píng)論0 收藏0
  • 流暢 Python - 0. 數(shù)據(jù)模型

    摘要:于是打算看一下流暢的。第一章是講數(shù)據(jù)模型,主要是的魔術(shù)方法特殊方法,它們以雙下劃線開頭和結(jié)束,能讓我們自己寫的類擁有類似內(nèi)置對(duì)象那樣的屬性和方法。第三個(gè)出場(chǎng)的的是,把對(duì)象用字符串的形式表示出來。第六個(gè)是,用于實(shí)現(xiàn)自己定義的布爾值。 接觸 Python 有一段時(shí)間了,但是到現(xiàn)在也沒怎么用 Python 寫過一些有用的東西?;A(chǔ)雖然還行,但更深入的就不怎么了解了。于是打算看一下《流暢的 P...

    Bowman_han 評(píng)論0 收藏0
  • [零基礎(chǔ)學(xué)python]大話題小函數(shù)(1)

    摘要:開篇就要提到一個(gè)大的話題編程范型。例如,在面向?qū)ο缶幊讨?,程序員認(rèn)為程序是一系列相互作用的對(duì)象,而在函數(shù)式編程中一個(gè)程序會(huì)被看作是一個(gè)無狀態(tài)的函數(shù)計(jì)算的串行。 開篇就要提到一個(gè)大的話題:編程范型。什么是編程范型?引用維基百科中的解釋: 編程范型或編程范式(英語:Programming paradigm),(范即模范之意,范式即模式、方法),是一類典型的編程風(fēng)格,是指從事軟件工程...

    xiguadada 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<