python中怎样定义一个字典
python如何输入字典的名称?
python如何输入字典的名称?
通过字典赋值的方式来实现。先写变量,然后将写好的字典数据赋值给变量,简单来说就是变量dict大括号,这样的方式来进行变量赋值,直接调用变量名就完成了对字典的使用,这个变量名就是字典的名称,它所指向的内存地址也是不会变的,唯一数据。
python字典类型可以修改吗?
可以修改,只有元组类型不可以修改。
哪条语句定义了python的字典?
格式 : name { key1 : value1 , key2 : value2 ,……} 由键值对组成,键必须是不可变数据类型组成,一般是唯一的,如果重复则会覆盖 例 :
dict { #34 性别 #34 : #34 女 #34 , #34 年龄 #34 : 18}
字典中的一个键可以有几个值?
字典中的值没有任何限制, 可以是任意Python对象,即从标准对象到用户自定义对象皆可,但是字典中的键是有类型限制的。 1、不允许一个键对应多个值。必须明确一条原则:每个键只能对应一个项。也就是说:一键对应多个值是不允许的(像列表、元组和其他字典这样的容器对象是可以的)。
当有键发生冲突(即字典键重复赋值),取最后(最近)的赋值。
Python并不会因字典中的键存在冲突而产生一个错误,它不会检查键的冲突是因为如果真这样做的话,在每个键-值对赋值的时候都会做检查,这将会占用一定量的内存。
如:gtgtgt dict1 {#39foo#39:789, #39foo#39: #39xyz#39} gtgtgt dict1 结果:{#39foo#39: #39xyz#39
} (2)键必须是可哈希的。大多数Python对象可以作为键,但它们必须是可哈希的对象。像列表和字典这样的可变类型,由于它们不是可哈希的,所以不能作为键。
所有不可变的类型都是可哈希的,因此它们都可以做为字典的键。
python如何定义函数?
一、定义一个最简单的函数
函数定义用def,必须要有函数名和函数体。下图中,函数名是sayHello,函数体是print语句。函数不被调用是不会执行的,调用时用函数名 括号的格式,即sayHello()
二、函数的参数
1、位置参数
位置参数,是必填的,调用函数时不传会报错。
我们写一个简单的函数,实现计算乘法的功能。下图中的a和b就是位置参数。
a,b叫做形参,也就是形式参数。调用函数calc时,传的7和8叫实参,也就是实际参数。
我们可以看到传参数时,7传给了a,8传给了b。也就是说传参顺序不能错。那么,当参数很多的时候,很难准确的记住各参数位置,就很容易出现错误,可以用 形参名实参 的方式传参。
例,操作数据库的函数。传参没有按顺序,采用了port 3306这种方式,很适合多参数的函数。
def op_mysql(host,port,username,password,db,sql): print(连接数据库:%s,host:%s,端口为:%s%(db,host,port)) print(%s where username%s and pwd %s%(sql,username,password)) op_mysql(sqlselect * from user, host192.158.11.1, usernamesdfdsfs, passwordsdf123, dbtest_data, port3306 )运行结果为:
2、默认值参数
默认值参数是非必填的,如果不填,会采用默认值。
例:写一个函数,实现文件读写的功能。
# 操作文件的函数,如果传内容参数,则将对应内容写入文件。没有传内容,就读取文件原来的内容。def op_file(file_name,contentNone): f open(file_name, a , encodingutf-8) (0) if content:#不为空代表写 f.write(content) f.flush() else: res () return res ()# 不传content,读文件stu_info op_file(username)print(stu_info)# 传content,将content写入文件infos xiaohei,123456,beijing,188888888888op_file(new_info,infos)这里介绍一下return,return有两个作用:(1)调用完函数后,将结果返回;(2)函数里面遇到return就立即结束。
另外,如果只写一个return,后面什么也不加,就返回None;如果不写return,也默认返回None。
小练习:写一个判断是否为小数的函数。
分析:(1)判断小数点个数;(2)如果是正小数,小数点左边和右边都是纯数字;(3)负小数,左边以‘-’开头,其他部分是数字,右边是数字。
def is_float(s): s str(s) if (.) 1: left s.split(.)[0]#小数左边 right s.split(.)[1]#小数右边 if () and (): return True# 正小数 elif (-) and (-) 1 and left.split(-)[1].isdigit() and (): return True# 负小数 else: return False else: return False num input(请输入:) res is_float(num)print(res)3、参数组
参数组的参数处用“*args”表示。参数组特点:(1)参数是非必填的;(2)没有限制参数的个数;(3)传过来的参数放到args参数里,不限格式
如果定义函数时,写成 def aaa(a,*args),则a是必传参数,*args是非必填的
4、关键字参数
关键字参数用“**kwargs”表示。特点:(1)参数是非必填;(2)没有限制参数个数;(3)所传参数必须是字典格式。
同样的,如果def aaa(time,**kwargs),则time参数必传。其中,time20180912是第一个参数time的值,因此输出kwargs时,没有time这一项。
三、局部变量和全局变量
1、局部变量
函数里面定义的变量都是局部变量,只能在函数里面用,出了函数就不能用了。
例如,第二节的小练习里,判断是否是小数的函数,left和right就是局部变量。
2、全局变量
全局变量是公共的变量,都可以用的变量。一般不推荐用全局变量,因为全局变量有以下2个缺点:(1)不安全,因为所有人都可以改;(2)会一直占着内存。
修改全局变量,需要先声明,用global声明。
下图中,name是一个全局变量,修改之前需要先声明:global name
四、内置函数
内置函数就是python里自带的一些函数,有很多,比如:
五、递归
递归就是函数自己调用自己。
建议少用递归,因为递归效率不高,而且最多递归999次。由下面的函数能够很直观的看出递归次数上限。
六、函数的返回值
前面已经简单介绍过return,return有两个作用:(1)调用完函数后,将结果返回;(2)函数里面遇到return就立即结束。
有的函数不只有一个返回值,函数如果返回多个值的话,会把这几个值放到一个元组里。另外,也可以用多个值来接收。
例:
七、匿名函数
匿名函数的功能很简单,只用一次。下面就定义了一个匿名函数。
用lambda定义匿名函数,冒号前面是返回值,后面是函数体,也就是函数的处理逻辑。
即入参是x,然后执行x 1,把x的值返回。
---------------河南新华