本文目录一览:
1、python里面有哪些自带函数?
2、Python的函数都有哪些?
3、Python中冷门但非常好用的内置函数
4、Python常用函数三有哪些?这7个函数使用频率最高,总算搞明白了
python里面有哪些自带函数?
python系统提供了下面常用的函数:
- 数学库模块(math)提供了很多数学运算函数;
- 复数模块(cmath)提供了用于复数运算的函数;
- 随机数模块(random)提供了用来生成随机数的函数;
- 时间(time)和日历(calendar)模块提供了能处理日期和时间的函数。
注意:在调用系统函数之前,先要使用
import
语句导入相应的模块。
该语句将模块中定义的函数代码复制到自己的程序中,然后就可以访问模块中的任何函数,其方法是在函数名前面加上“模块名.”。 希望能帮到你。
Python的函数都有哪些?
Python 函数
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。
函数能提高应用的模块性,和代码的重复利用率。你已经知道Python提供了许多内建函数,比如print()
。但你也可以自己创建函数,这被叫做用户自定义函数。
定义一个函数
你可以定义一个由自己想要功能的函数,以下是简单的规则:
- 函数代码块以
def
关键词开头,后接函数标识符名称和圆括号()
。 - 任何传入参数和自变量必须放在圆括号中间。圆括号之间可以用于定义参数。
- 函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明。
- 函数内容以冒号起始,并且缩进。
return [表达式]
结束函数,选择性地返回一个值给调用方。不带表达式的return
相当于返回None
。
语法
def functionname( parameters ):
"函数_文档字符串"
function_suite
return [expression]
默认情况下,参数值和参数名称是按函数声明中定义的顺序匹配起来的。
实例
以下为一个简单的Python函数,它将一个字符串作为传入参数,再打印到标准显示设备上。
def printme( str ):
"打印传入的字符串到标准显示设备上"
print str
return
函数调用
定义一个函数只给了函数一个名称,指定了函数里包含的参数,和代码块结构。这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从Python提示符执行。
如下实例调用了printme()
函数:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 定义函数
def printme( str ):
"打印任何传入的字符串"
print str
return
# 调用函数
printme("我要调用用户自定义函数!")
printme("再次调用同一函数")
以上实例输出结果:
我要调用用户自定义函数!
再次调用同一函数
参数传递
在 Python 中,类型属于对象,变量是没有类型的:
a = [1, 2, 3]
a = "Runoob"
以上代码中,[1, 2, 3]
是 List 类型,"Runoob"
是 String 类型,而变量 a
是没有类型的,它仅仅是一个对象的引用(一个指针),可以是 List 类型对象,也可以指向 String 类型对象。
可更改(mutable)与不可更改(immutable)对象
- 不可变类型:类似 C++ 的值传递,如整数、字符串、元组。如
fun(a)
,传递的只是a
的值,没有影响a
对象本身。比如在fun(a)
内部修改a
的值,只是修改另一个复制的对象,不会影响a
本身。 - 可变类型:类似 C++ 的引用传递,如列表、字典。如
fun(la)
,则是将la
真正的传过去,修改后fun
外部的la
也会受影响。 Python 中一切都是对象,严格意义上我们不能说值传递还是引用传递,我们应该说传不可变对象和传可变对象。
不可变对象实例
def ChangeInt( a ):
a = 10
b = 2
ChangeInt(b)
print(b) # 结果是 2
实例中有 int
对象 2,指向它的变量是 b
,在传递给 ChangeInt
函数时,按传值的方式复制了变量 b
,a
和 b
都指向了同一个 Int
对象,在 a=10
时,则新生成一个 int
值对象 10,并让 a
指向它。
可变对象实例
def changeme( mylist ):
"修改传入的列表"
mylist.append([1,2,3,4])
print "函数内取值: ", mylist
return
mylist = [10,20,30]
changeme( mylist )
print "函数外取值: ", mylist
实例中传入函数的和在末尾添加新内容的对象用的是同一个引用,故输出结果如下:
函数内取值: [10, 20, 30, [1, 2, 3, 4]]
函数外取值: [10, 20, 30, [1, 2, 3, 4]]
参数
以下是调用函数时可使用的正式参数类型:
- 必备参数
- 关键字参数
- 默认参数
- 不定长参数
必备参数
必备参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。
调用printme()
函数,你必须传入一个参数,不然会出现语法错误:
def printme( str ):
"打印任何传入的字符串"
print str
return
printme()
以上实例输出结果:
Traceback (most recent call last):
File "test.py", line 11, in module
printme()
TypeError: printme() takes exactly 1 argument (0 given)
关键字参数
关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。
使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
以下实例在函数 printme()
调用时使用参数名:
def printme( str ):
"打印任何传入的字符串"
print str
return
printme( str = "My string")
以上实例输出结果:
My string
下例能将关键字参数顺序不重要展示得更清楚:
def printinfo( name, age ):
"打印任何传入的字符串"
print "Name: ", name
print "Age ", age
return
printinfo( age=50, name="miki" )
以上实例输出结果:
Name: miki
Age 50
默认参数
调用函数时,默认参数的值如果没有传入,则被认为是默认值。下例会打印默认的age
,如果age
没有被传入:
def printinfo( name, age = 35 ):
"打印任何传入的字符串"
print "Name: ", name
print "Age ", age
return
printinfo( age=50, name="miki" )
printinfo( name="miki" )
以上实例输出结果:
Name: miki
Age 50
Name: miki
Age 35
不定长参数
你可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。基本语法如下:
def functionname([formal_args,] *var_args_tuple ):
"函数_文档字符串"
function_suite
return [expression]
加了星号(*
)的变量名会存放所有未命名的变量参数。不定长参数实例如下:
def printinfo( arg1, *vartuple ):
"打印任何传入的参数"
print "输出: "
print arg1
for var in vartuple:
print var
return
printinfo( 10 )
printinfo( 70, 60, 50 )
以上实例输出结果:
输出:
10
输出:
70
60
50
匿名函数
Python 使用 lambda
来创建匿名函数。
lambda
只是一个表达式,函数体比def
简单很多。
lambda
的主体是一个表达式,而不是一个代码块。仅仅能在lambda
表达式中封装有限的逻辑进去。
lambda
函数拥有自己的命名空间,且不能访问自有参数列表之外或全局命名空间里的参数。
虽然lambda
函数看起来只能写一行,却不等同于C或C++的内联函数,后者的目的是调用小函数时不占用栈内存从而增加运行效率。
语法
lambda
函数的语法只包含一个语句,如下:
lambda [arg1 [,arg2,.....argn]]:expression
如下实例:
sum = lambda arg1, arg2: arg1 + arg2
print "相加后的值为 : ", sum( 10, 20 )
print "相加后的值为 : ", sum( 20, 20 )
以上实例输出结果:
相加后的值为 : 30
相加后的值为 : 40
return 语句
return
语句[表达式]退出函数,选择性地向调用方返回一个表达式。不带参数值的return
语句返回None
。之前的例子都没有示范如何返回数值,下例便告诉你怎么做:
def sum( arg1, arg2 ):
# 返回2个参数的和."
total = arg1 + arg2
print "函数内 : ", total
return total
total = sum( 10, 20 )
以上实例输出结果:
函数内 : 30
变量作用域
一个程序的所有的变量并不是在哪个位置都可以访问的。访问权限决定于这个变量是在哪里赋值的。 变量的作用域决定了在哪一部分程序你可以访问哪个特定的变量名称。两种最基本的变量作用域如下:
- 全局变量
- 局部变量
全局变量和局部变量
定义在函数内部的变量拥有一个局部作用域,定义在函数外的拥有全局作用域。 局部变量只能在其被声明的函数内部访问,而全局变量可以在整个程序范围内访问。调用函数时,所有在函数内声明的变量名称都将被加入到作用域中。如下实例:
total = 0 # 这是一个全局变量
def sum( arg1, arg2 ):
#返回2个参数的和."
total = arg1 + arg2 # total在这里是局部变量.
print "函数内是局部变量 : ", total
return total
sum( 10, 20 )
print "函数外是全局变量 : ", total
以上实例输出结果:
函数内是局部变量 : 30
函数外是全局变量 : 0
Python中冷门但非常好用的内置函数
Python中有许多内置函数,不像print
、len
那么广为人知,但它们的功能却异常强大,用好了可以大大提高代码效率,同时提升代码的简洁度,增强可阅读性。
Counter
collections
在Python官方文档中的解释是High-performance container datatypes,直接的中文翻译解释为高性能容量数据类型。这个模块实现了特定目标的容器,以提供Python标准内建容器 dict
、list
、set
和 tuple
的替代选择。在Python 3.10.1中它总共包含以下几种数据类型:
容器名 | 简介 |
---|---|
namedtuple() |
创建命名元组子类的工厂函数 |
deque |
类似列表(list)的容器,实现了在两端快速添加(append)和弹出(pop) |
ChainMap |
类似字典(dict)的容器类,将多个映射集合到一个视图里面 |
Counter |
字典的子类,提供了可哈希对象的计数功能 |
OrderedDict |
字典的子类,保存了它们被添加的顺序 |
defaultdict |
字典的子类,提供了一个工厂函数,为字典查询提供一个默认值 |
UserDict |
封装了字典对象,简化了字典子类化 |
UserList |
封装了列表对象,简化了列表子类化 |
UserString |
封装了字符串对象,简化了字符串子类化 |
其中Counter 中文意思是计数器,也就是我们常用于统计的一种数据类型,在使用Counter 之后可以让我们的代码更加简单易读。Counter 类继承dict 类,所以它能使用dict 类里面的方法。 |
举例
# 统计词频
fruits = ['apple', 'peach', 'apple', 'lemon', 'peach', 'peach']
result = {}
for fruit in fruits:
if not result.get(fruit):
result[fruit] = 1
else:
result[fruit] += 1
print(result)
# {'apple': 2, 'peach': 3, 'lemon': 1}
下面我们看用Counter
怎么实现:
from collections import Counter
fruits = ['apple', 'peach', 'apple', 'lemon', 'peach', 'peach']
c = Counter(fruits)
print(dict(c))
# {'apple': 2, 'peach': 3, 'lemon': 1}
显然代码更加简单了,也更容易阅读和维护了。
elements()
返回一个迭代器,其中每个元素将重复出现计数值所指定次。元素会按首次出现的顺序返回。如果一个元素的计数值小于1,elements()
将会忽略它。
c = Counter(a=4, b=2, c=0, d=-2)
sorted(c.elements())
# ['a', 'a', 'a', 'a', 'b', 'b']
most_common([n])
返回一个列表,其中包含n个最常见的元素及出现次数,按常见程度由高到低排序。如果n被省略或为None,most_common()
将返回计数器中的所有元素。计数值相等的元素按首次出现的顺序排序:
Counter('abracadabra').most_common(3)
# [('a', 5), ('b', 2), ('r', 2)]
这两个方法是Counter
中最常用的方法,其他方法可以参考 Python 3.10.1官方文档。
实战
Leetcode 1002. 查找共用字符
给你一个字符串数组words
,请你找出所有在words
的每个字符串中都出现的共用字符(包括重复字符),并以数组形式返回。你可以按任意顺序返回答案。
输入:words = ["bella", "label", "roller"]
输出:["e", "l", "l"]
输入:words = ["cool", "lock", "cook"]
输出:["c", "o"]
看到统计字符,典型的可以用Counter
完美解决。这道题是找出字符串列表里面每个元素都包含的字符,首先可以用Counter
计算出每个元素每个字符出现的次数,依次取交集最后得出所有元素共同存在的字符,然后利用elements
输出共用字符出现的次数。
class Solution:
def commonChars(self, words: List[str]) -> List[str]:
from collections import Counter
ans = Counter(words[0])
for i in words[1:]:
ans &= Counter(i)
return list(ans.elements())
提交一下,发现83个测试用例耗时48ms,速度还是不错的。
sorted
在处理数据过程中,我们经常会用到排序操作,比如将列表、字典、元组里面的元素正/倒排序。这时候就需要用到sorted()
,它可以对任何可迭代对象进行排序,并返回列表。
对列表升序操作:
a = sorted([2, 4, 3, 7, 1, 9])
print(a)
# 输出:[1, 2, 3, 4, 7, 9]
对元组倒序操作:
sorted((4,1,9,6), reverse=True)
print(a)
# 输出:[9, 6, 4, 1]
使用参数:key,根据自定义规则,按字符串长度来排序:
fruits = ['apple', 'watermelon', 'pear', 'banana']
a = sorted(fruits, key=lambda x: len(x))
print(a)
# 输出:['pear', 'apple', 'banana', 'watermelon']
all
all()
函数用于判断给定的可迭代参数iterable
中的所有元素是否都为 True
,如果是返回 True
,否则返回 False
。元素除了是 0
、空、None
、False
外都算True
。注意:空元组、空列表返回值为True
。
all(['a', 'b', 'c', 'd']) # 列表list,元素都不为空或0
# True
all(['a', 'b', '', 'd']) # 列表list,存在一个为空的元素
# False
all([0, 1, 2, 3]) # 列表list,存在一个为0的元素
# False
all(('a', 'b', 'c', 'd')) # 元组tuple,元素都不为空或0
# True
all(('a', 'b', '', 'd')) # 元组tuple,存在一个为空的元素
# False
all((0, 1, 2, 3)) # 元组tuple,存在一个为0的元素
# False
all([]) # 空列表
# True
all(()) # 空元组
# True
any
函数正好和all
函数相反:判断一个tuple或者list是否全为空,0,False。如果全为空,0,False,则返回False
;如果不全为空,则返回True
。
F-strings
在Python 3.6.2版本中,PEP 498提出一种新型字符串格式化机制,被称为 “字符串插值” 或者更常见的一种称呼是F-strings,F-strings提供了一种明确且方便的方式将Python表达式嵌入到字符串中来进行格式化:
s1 = 'Hello'
s2 = 'World'
print(f'{s1} {s2}!')
# Hello World!
在F-strings中我们也可以执行函数:
def power(x):
return x * x
x = 4
print(f'{x} * {x} = {power(x)}')
# 4 * 4 = 16
而且F-strings的运行速度很快,比传统的%-string
和str.format()
这两种格式化方法都快得多,书写起来也更加简单。
本文主要讲解了Python几种冷门但好用的函数,更多内容以后会陆陆续续更新~
Python常用函数三有哪些?这7个函数使用频率最高,总算搞明白了
1.1 例如:print(hex(2))
1.2 输出函数:print(hex(2))
1.3 输出结果:0x2
1.4 解析说明:返回16进制的数。
2.1 例如:print(chr(10))
2.2 输出函数:print(chr(10))
2.3 输出结果:0o12
2.4 解析说明:返回当前整数对应的ASCII码。
3.1 例如:print(ord("b"))
3.2 输出函数:print(ord("b"))
3.3 输出结果:98
3.4 解析说明:返回当前ASCII码的10进制数。
4.1 例如:print(chr(97))
4.2 输出函数:print(chr(97))
4.3 输出结果:a
4.4 解析说明:返回当前ASCII码的10进制数。
案例一:给你一个字符串,s = 'hello kitty'
1.1 输出函数:print(s.capitalize())
1.2 输出结果:Hello kitty
1.3 解析说明:将字符串首字母大写。
2.1 输出函数:print(s.replace('kitty','kuang'))
2.2 输出结果:hello kuang
2.3 解析说明:替换功能,将kitty
换成kuang
。
2.4 输出函数:print(s.replace('4','KK'))
2.5 输出结果:hello kitty
2.6 解析说明:字符串中没有4
,所以不替换。
案例二:给你一个字符串,ip = '192.168.1.1'
3.1 输出函数:print(ip.split('.'))
3.2 输出结果:['192', '168', '1', '1']
3.3 解析说明:将字符串按.
分割成列表。
3.4 输出函数:print(ip.split('.', 2))
3.5 输出结果:['192', '168', '1.1']
3.6 解析说明:最多分割2次。