Rumah pembangunan bahagian belakang Tutorial Python Python基础知识之函数总结

Python基础知识之函数总结

Apr 02, 2018 am 09:46 AM
python fungsi

本篇文章给大家分享的是Python基础知识之函数总结,内容挺不错的,希望可以帮助到有需要的朋友。

函数:包含自定义函数、内置函数<br>

1)自定义函数结构:包含五个部分:

  • def关键字:识别用于创建函数

  • 函数名:比如f1

  • ():()里面有参数

  • 函数体:具体这个函数要实现的功能

  • return:返回值,如果无,则返回none

如下所示:

640?wx_fmt=png&wxfrom=5&wx_lazy=1

2)函数的调用:用函数名+()

形式为:函数名(参数1,参数2),比如f1(5,8)

3)函数的执行顺序:自上至下。

    而函数体只有在被调用的时候才执行

    如果要取函数的返回值,需要赋值。

    函数体中的return后的语句不再执行。<br>

640?wx_fmt=png&wxfrom=5&wx_lazy=1

执行结果:

0?wx_fmt=png

案例1:自定义函数,因为没有调用函数,所以函数体不执行<br>

f1():
()
Salin selepas log masuk

<br>

案例2,调用函数,执行函数体。函数体中一旦执行到return,则立即终止,因此后面的print(456)永远不会执行。

f1():
()
()
Salin selepas log masuk
f1()
Salin selepas log masuk

案例执行结果为:123

案例3,结果为123、111,因为有return把值给了r,print(r)打印出来111

f1():
()
r=f1()
(r)
Salin selepas log masuk
Salin selepas log masuk

案例执行结果为:123、111

案例4:当函数无return的时候,自动默认返回值为None;返回结果为123、None,因为没有return,r接受到的值为None

f1():
()
r=f1()
(r)
Salin selepas log masuk
Salin selepas log masuk

案例执行结果为:123、none

案例5:python传递的是引用,不是复制,如下的li经过函数体执行后,已经被引用了

f1(a1):
    a1.append()
li=[,,,]
(li)
f1(li)
(li)
Salin selepas log masuk

执行结果:

[11, 22, 33, 44]

[11, 22, 33, 44, 999]

<br>

4)函数的参数:<br>

比如f(x1,x2,x3=1),x1,x2,x3则为参数

包含的参数类型有:

            普通参数:形式参数和实际参数<br>

            默认参数:提前给定值,比如x3<br>

            指定参数:实际参数调用时,可以改变顺序指定

            动态参数:<br>

                *args<br>

                **kargs<br>

                万能参数*args,**kagrs

<br>

案例1:区分形式参数和实际参数:

案例中的xxx为形式参数,调用函数时传递的为实际参数<br>

f1(xxx):
()
xxx+r=f1()
(r)
Salin selepas log masuk

<br>

案例2:理解参数的调用

普通参数,x1、x2,在f1里面按顺序传递

<br>
Salin selepas log masuk
Salin selepas log masuk
f1(x1,x2):
x1+x2
r=f1(,)
Salin selepas log masuk

默认参数,如果设置,则该形式参数必须放后面,如x3,调用时不用再次传递

f1(x1,x2,x3=):
x1+x2+x3
r=f1(,)
Salin selepas log masuk

指定参数,指定参数可以改变顺序指定

<br>
Salin selepas log masuk
Salin selepas log masuk
f1(x1,x2,x3=):
x1+x2+x3
f1(x2=,x1=)
(r)
Salin selepas log masuk

案例3:动态函数(函数名前加*,或者**):一个形式参数,可以接受多个实际参数。

当形式参数带*时,默认将传递的参数放置在群组中

  • 当实际参数为普通参数传递时,即使列表,也会被作为一个元素传递

  • 当实际参数有*时,list所有的元素将相应的作为元祖的每一个元素

(x,(x))
f1(,,)
li=[,,,]
f1(li)
f1(*li)
Salin selepas log masuk

执行结果:

('55', 66, 'll')

([11, 22, 33, 'hhhh'],)

(11, 22, 33, 'hhhh')

<br>

当为**时,默认传递的参数放置在字典中,实际参数必须为指定参数或字典

案例4:如果形式参数为**,传递实际参数的时候也传递**,则会把整个字典传进去

f1(**x):
(x,(x))
f1(=,=)
dic={:,:}
f1(**dic)
Salin selepas log masuk

执行结果:<br>

{'n1': 'hh', 'n2': 'kk'}

{'k1': 'n1', 'k2': 'n2'}

<br>

案例5:万能参数:f1(*args,**args),必须*在前,**在后

f1(*a,**x):
(a,(a))
(x,(x))
f1(,,,**{:,:})
Salin selepas log masuk

执行结果

(11, 22, 33)

{'k1': 'n1', 'k2': 'n2'}

<br>

关于万能参数的应用,就是str.format

案例6:用占位符传递,这样是*arg的应用

s1=.format(,)
s2=.format(*[,])
(s1)
(s2)
Salin selepas log masuk

执行结果:

i am hh,age2

i am hh,age2

<br>

案例7:当形式参数为字符变量时,必须后面指定参数传递,为**arg的应用

=.format(=,=)
dic={:,:}
s2=.format(**dic)
()
(s2)
Salin selepas log masuk

执行结果:

i am hh,age2

i am nn,age4

<br>

5)全局变量:作用在全局,用大写表示,如果要修改且作用于全局,则需要加global

案例1:全局变量:作用域在全局,用大写表示。<br>

=f1():
    age=(age,)
f2():
    age = (age, )
f1()
f2()
Salin selepas log masuk

0?wx_fmt=png

案例2:修改全局变量:如果要修改且对全局有用,则可以用global

NAME=f1():
    age=NAME
    NAME = (age,NAME)
f2():
    age = (age, NAME)
f1()
f2()
Salin selepas log masuk

执行结果:

640?wx_fmt=png

案例3:修改全局变量:不加global,则仅作用在函数内部

=f1():
    age= = (age,)
f2():
    age = (age, )
f1()
f2()
Salin selepas log masuk

执行结果:

0?wx_fmt=png

<br>

6)三元\三目运算:即if..else的简称。

格式为:"为真时的结果   if 判定条件    else 为假时的结果" ,

“condition ? true_part : false_part”
Salin selepas log masuk


案例1:如果1==1条件成立,就等于前面的值,否则为后面的值hhh

==:
    name=:
    name=name2===
Salin selepas log masuk

6)lambda函数:目的就是简化用户定义使用函数的过程

案例1:lambda函数,简写函数,一个参数

f1(a1):
a1+ret=f1()
(ret)
Salin selepas log masuk

#案例可以简写

=a1:a1+r1=()
(r1)
Salin selepas log masuk

案例2:lambda函数,简写俩参数

=a1,a2:a1*a2+r1=(,)
(r1)
Salin selepas log masuk

案例3:应用lambda函数

=[,,,,,]
key=w:[w]
r=key()
(r)
Salin selepas log masuk

案例4:循环用法案例

=n=alphabet=s3=[[:i]+c+[i+:] i () c alphabet]
(s3)
Salin selepas log masuk

执行结果为:
Salin selepas log masuk

0?wx_fmt=png

7)python有很多内置函数,可以直接使用

可参考:http://www.cnblogs.com/vamei/archive/2012/11/09/2762224.html

0?wx_fmt=png

Atas ialah kandungan terperinci Python基础知识之函数总结. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Adakah Mysql perlu membayar Adakah Mysql perlu membayar Apr 08, 2025 pm 05:36 PM

MySQL mempunyai versi komuniti percuma dan versi perusahaan berbayar. Versi komuniti boleh digunakan dan diubahsuai secara percuma, tetapi sokongannya terhad dan sesuai untuk aplikasi dengan keperluan kestabilan yang rendah dan keupayaan teknikal yang kuat. Edisi Enterprise menyediakan sokongan komersil yang komprehensif untuk aplikasi yang memerlukan pangkalan data yang stabil, boleh dipercayai, berprestasi tinggi dan bersedia membayar sokongan. Faktor yang dipertimbangkan apabila memilih versi termasuk kritikal aplikasi, belanjawan, dan kemahiran teknikal. Tidak ada pilihan yang sempurna, hanya pilihan yang paling sesuai, dan anda perlu memilih dengan teliti mengikut keadaan tertentu.

Cara Menggunakan MySQL Selepas Pemasangan Cara Menggunakan MySQL Selepas Pemasangan Apr 08, 2025 am 11:48 AM

Artikel ini memperkenalkan operasi pangkalan data MySQL. Pertama, anda perlu memasang klien MySQL, seperti MySqlworkbench atau Command Line Client. 1. Gunakan perintah MySQL-Uroot-P untuk menyambung ke pelayan dan log masuk dengan kata laluan akaun root; 2. Gunakan CreateTatabase untuk membuat pangkalan data, dan gunakan Pilih pangkalan data; 3. Gunakan createtable untuk membuat jadual, menentukan medan dan jenis data; 4. Gunakan InsertInto untuk memasukkan data, data pertanyaan, kemas kini data dengan kemas kini, dan padam data dengan padam. Hanya dengan menguasai langkah -langkah ini, belajar menangani masalah biasa dan mengoptimumkan prestasi pangkalan data anda boleh menggunakan MySQL dengan cekap.

Mysql tidak dapat dipasang setelah memuat turun Mysql tidak dapat dipasang setelah memuat turun Apr 08, 2025 am 11:24 AM

Sebab utama kegagalan pemasangan MySQL adalah: 1. Isu kebenaran, anda perlu menjalankan sebagai pentadbir atau menggunakan perintah sudo; 2. Ketergantungan hilang, dan anda perlu memasang pakej pembangunan yang relevan; 3. Konflik pelabuhan, anda perlu menutup program yang menduduki port 3306 atau mengubah suai fail konfigurasi; 4. Pakej pemasangan adalah korup, anda perlu memuat turun dan mengesahkan integriti; 5. Pembolehubah persekitaran dikonfigurasikan dengan salah, dan pembolehubah persekitaran mesti dikonfigurasi dengan betul mengikut sistem operasi. Selesaikan masalah ini dan periksa dengan teliti setiap langkah untuk berjaya memasang MySQL.

Fail muat turun MySQL rosak dan tidak boleh dipasang. Penyelesaian pembaikan Fail muat turun MySQL rosak dan tidak boleh dipasang. Penyelesaian pembaikan Apr 08, 2025 am 11:21 AM

Fail muat turun mysql adalah korup, apa yang perlu saya lakukan? Malangnya, jika anda memuat turun MySQL, anda boleh menghadapi rasuah fail. Ia benar -benar tidak mudah hari ini! Artikel ini akan bercakap tentang cara menyelesaikan masalah ini supaya semua orang dapat mengelakkan lencongan. Selepas membacanya, anda bukan sahaja boleh membaiki pakej pemasangan MySQL yang rosak, tetapi juga mempunyai pemahaman yang lebih mendalam tentang proses muat turun dan pemasangan untuk mengelakkan terjebak pada masa akan datang. Mari kita bercakap tentang mengapa memuat turun fail rosak. Terdapat banyak sebab untuk ini. Masalah rangkaian adalah pelakunya. Gangguan dalam proses muat turun dan ketidakstabilan dalam rangkaian boleh menyebabkan rasuah fail. Terdapat juga masalah dengan sumber muat turun itu sendiri. Fail pelayan itu sendiri rosak, dan sudah tentu ia juga dipecahkan jika anda memuat turunnya. Di samping itu, pengimbasan "ghairah" yang berlebihan beberapa perisian antivirus juga boleh menyebabkan rasuah fail. Masalah Diagnostik: Tentukan sama ada fail itu benar -benar korup

Penyelesaian kepada perkhidmatan yang tidak dapat dimulakan selepas pemasangan MySQL Penyelesaian kepada perkhidmatan yang tidak dapat dimulakan selepas pemasangan MySQL Apr 08, 2025 am 11:18 AM

MySQL enggan memulakan? Jangan panik, mari kita periksa! Ramai kawan mendapati bahawa perkhidmatan itu tidak dapat dimulakan selepas memasang MySQL, dan mereka sangat cemas! Jangan risau, artikel ini akan membawa anda untuk menangani dengan tenang dan mengetahui dalang di belakangnya! Selepas membacanya, anda bukan sahaja dapat menyelesaikan masalah ini, tetapi juga meningkatkan pemahaman anda tentang perkhidmatan MySQL dan idea anda untuk masalah penyelesaian masalah, dan menjadi pentadbir pangkalan data yang lebih kuat! Perkhidmatan MySQL gagal bermula, dan terdapat banyak sebab, mulai dari kesilapan konfigurasi mudah kepada masalah sistem yang kompleks. Mari kita mulakan dengan aspek yang paling biasa. Pengetahuan asas: Penerangan ringkas mengenai proses permulaan perkhidmatan MySQL Startup. Ringkasnya, sistem operasi memuatkan fail yang berkaitan dengan MySQL dan kemudian memulakan daemon MySQL. Ini melibatkan konfigurasi

Adakah mysql memerlukan internet Adakah mysql memerlukan internet Apr 08, 2025 pm 02:18 PM

MySQL boleh berjalan tanpa sambungan rangkaian untuk penyimpanan dan pengurusan data asas. Walau bagaimanapun, sambungan rangkaian diperlukan untuk interaksi dengan sistem lain, akses jauh, atau menggunakan ciri -ciri canggih seperti replikasi dan clustering. Di samping itu, langkah -langkah keselamatan (seperti firewall), pengoptimuman prestasi (pilih sambungan rangkaian yang betul), dan sandaran data adalah penting untuk menyambung ke Internet.

Bagaimana untuk mengoptimumkan prestasi MySQL untuk aplikasi beban tinggi? Bagaimana untuk mengoptimumkan prestasi MySQL untuk aplikasi beban tinggi? Apr 08, 2025 pm 06:03 PM

Panduan Pengoptimuman Prestasi Pangkalan Data MySQL Dalam aplikasi yang berintensifkan sumber, pangkalan data MySQL memainkan peranan penting dan bertanggungjawab untuk menguruskan urus niaga besar-besaran. Walau bagaimanapun, apabila skala aplikasi berkembang, kemunculan prestasi pangkalan data sering menjadi kekangan. Artikel ini akan meneroka satu siri strategi pengoptimuman prestasi MySQL yang berkesan untuk memastikan aplikasi anda tetap cekap dan responsif di bawah beban tinggi. Kami akan menggabungkan kes-kes sebenar untuk menerangkan teknologi utama yang mendalam seperti pengindeksan, pengoptimuman pertanyaan, reka bentuk pangkalan data dan caching. 1. Reka bentuk seni bina pangkalan data dan seni bina pangkalan data yang dioptimumkan adalah asas pengoptimuman prestasi MySQL. Berikut adalah beberapa prinsip teras: Memilih jenis data yang betul dan memilih jenis data terkecil yang memenuhi keperluan bukan sahaja dapat menjimatkan ruang penyimpanan, tetapi juga meningkatkan kelajuan pemprosesan data.

Cara mengoptimumkan prestasi pangkalan data selepas pemasangan MySQL Cara mengoptimumkan prestasi pangkalan data selepas pemasangan MySQL Apr 08, 2025 am 11:36 AM

Pengoptimuman prestasi MySQL perlu bermula dari tiga aspek: konfigurasi pemasangan, pengindeksan dan pengoptimuman pertanyaan, pemantauan dan penalaan. 1. Selepas pemasangan, anda perlu menyesuaikan fail my.cnf mengikut konfigurasi pelayan, seperti parameter innodb_buffer_pool_size, dan tutup query_cache_size; 2. Buat indeks yang sesuai untuk mengelakkan indeks yang berlebihan, dan mengoptimumkan pernyataan pertanyaan, seperti menggunakan perintah menjelaskan untuk menganalisis pelan pelaksanaan; 3. Gunakan alat pemantauan MySQL sendiri (ShowProcessList, ShowStatus) untuk memantau kesihatan pangkalan data, dan kerap membuat semula dan mengatur pangkalan data. Hanya dengan terus mengoptimumkan langkah -langkah ini, prestasi pangkalan data MySQL diperbaiki.

See all articles