string formating字符串格式化,function函数,group组,recursion递归,练习
# -*- coding: UTF-8 -*-
msg = 'i am {} my hobby is {}'.format('lhf',18)
print(msg) msg1 = 'i am %s my hobby is %s' % ('lhf',[1,2])
print(msg1) name='lhf'
age=18
msg2 = 'i am %s my hobby is %s' % (name,age)
print(msg2) tpl = 'percent %.2f %%' % 99.9762333333333
print(tpl) tpl1 = 'i am %(name)s age %(age)d' % {'name':'alex','age':18}
print(tpl1) msg3 = 'i am %(name)+60s my hobby is alex' % {'name':'lhf'}
print(msg3) msg4 = 'i am \033[43;1m%(name)+60s\033[0m my hobby is alex' %{'name':'lhf'}
print(msg4) #print('root','x','0','0',sep=':') #结果(root:x:0:0) print('root'+':'+'x'+':'+'','') #结果('root:x:0', '0') result:
i am lhf my hobby is 18
i am lhf my hobby is [1, 2]
i am lhf my hobby is 18
percent 99.98 %
i am alex age 18
i am lhf my hobby is alex
i am [43;1m lhf[0m my hobby is alex
('root:x:0', '')
# -*- coding: UTF-8 -*-
name = '海风'
def huangwei():
name = '黄伟'
print(name)
def liuyang():
name = '刘洋'
print(name)
def nulige():
name = '炉指花'
print(name)
print(name)
nulige()
liuyang()
print(name)
print(name)
huangwei()
print(name) result:
海风
黄伟
刘洋
刘洋
炉指花
黄伟
海风
# -*- coding: UTF-8 -*-
def calc(n):
print(n)
if int(n/2) == 0:
return n
res = calc(int(n/2))
return res
calc(20) result:
20
10
5
2
1
集合特点:
1.由不同元素组成
2.集合无序
3.集合元素是不可变类型,包括(数字,字符串,元祖
#交叉补集
python_l = ['lcg','szw','zjw','lcg']
linux_l = ['lcg','szw','sb']
p_s = set(python_l)
l_s = set(linux_l)
print(p_s.symmetric_difference(l_s))
print(p_s^l_s)
p_s.difference_update(l_s) #等同于p_s = p_s - l_s
print(p_s)
s1 = {1,2}
s2 = {2,3,5}
print(s1.isdisjoint(s2)) #判断两个集合是否包含相同的元素 #子集,父集
s1 = {1,2}
s2 = {1,2,3}
print(s1.issubset(s2))#s1是s2的子集
print(s2.issubset(s1))
print(s2.issuperset(s1))#s1是s2的父集
s1.update(s2)#更新多个值
# s1.add(1,2,3,4)#更新一个值
# s1.union(s2)#不更新
print(s1)
s = frozenset('hello')#两种字典类型的区别
s5 = set('hello')
print(s,s5)
names = ['alex','alex','wupeiqi']
names = list(set(names))
print(names)
result:
{'zjw', 'sb'}
{'zjw', 'sb'}
{'zjw'}
False
True
False
True
{1, 2, 3}
frozenset({'e', 'o', 'l', 'h'}) {'e', 'o', 'l', 'h'}
['alex', 'wupeiqi']
可迭代类型:for循环可以遍历
函数形参与实参知识点:
位置参数(形如test(1,2,3)):实参和形参一一对应,缺一不行,多一也不行
关键字参数(形如test(x=1,z=3,y=2)):实参和形参无需一一对应,缺一不行,多一也不行
位置函数作为形参必须在关键字函数左边。
def test(x,*args) #*args用于函数扩展
模拟多级节点
方法一:
dic = {
'植物':
{'草本植物':
['牵牛花','瓜叶菊','葫芦','翠菊','冬小麦','甜菜'],
'水木植物':
['乔木','灌木','丰灌木','如松','杉'],
'水生植物':
['荷花','千屈菜','呂菊','黄奕菊','水葱','再力花','梭鱼草']},
'动物':
{'两栖动物':
['山龟','山鳖','石蛙','娃娃鱼','蟾蜍','龟','鳄鱼','蜥蜴','蛇'],
'禽类':
['知鸡','原鸡','长鸣鸡','昌国鸡','斗鸡','长尾鸡','乌骨鸡'],
'哺乳类动物':
['虎','狼','蛇','鹿','貂','猴','树懒','斑马','狗']}}
li = []
bool = True
while bool:
bool1 = True
for i,v in enumerate(dic,1):
print(i,v)
li.append(v)
print('要添加新种类请输入i,否则输入对应下一级数字查看菜单')
u_c = input('>>>')
if u_c.isdigit(): #数字用来选择
li1 = []
while bool:
u_c = int(u_c)
for j,k in enumerate(dic[li[u_c-1]],1):
print(j,k)
li1.append(k)
u_c1 = input('>>>>')
if u_c1 == 'b':
li.clear()
break
while bool:
for x,y in enumerate(dic[li[int(u_c-1)]][li1[int(u_c1)-1]],1):
print(x,y)
u_c2 = str(input('>>>>>'))
u_c2 = u_c2.lower()
if u_c2 == 'b':
# bool = False
li1.clear()
break
elif u_c2 == 'q':
li.clear()
bool = False
break
else:
continue
elif u_c.isalpha(): #字母i用来添加新种类
if u_c == 'i'or u_c == 'I':
while bool1:
lx = str(input('类型:'))
if dic.get(lx,1) == 1: #得到lx中的字符串,如果该字符串在dic第一层中没有,则返回后面值‘1’
dic[lx] = {}
zl = str(input('种类:'))
if dic[lx].get(zl,1) == 1: #得到lx中的字符串,如果该字符串在dic第一层中没有,则返回后面值‘1’
dic[lx][zl] = []
while bool1:
mc = input('名称:')
if mc == 'b':
li.clear()
bool1 = False
break
elif mc == 'q':
bool = False
break
elif mc in dic[lx][zl]:
print('已经存在')
else:
dic[lx][zl].append(mc)
方法二:(编程思路来自老男孩郑建文老师)
db = {
'北京':{},
'上海':{
'虹口':{
'外国语':'小明',
'西藏北路':'布丁酒店',
'上海南站':'高铁'},
'宝山':{
'大场':'蹦迪',
'上海大学':'钱伟长'},
'闵行':{
'上海交大':'闵行校区'
}
}
}
path = []
while True:
temp = db
for item in path:
temp = temp[item]
print('当前可选的所有子节点:',list(temp.keys()))
choice = input('1:添加节点; 2:查看节点(Q/B);\n >>>')
if choice == '':
name = input('请输入要添加的节点名称')
temp[name] = {}
elif choice == '':
name = input('请输入要查看的节点名称:')
path.append(name)
elif choice.lower() == 'b':
if path:
path.pop()
elif choice.lower() == 'q':
break
else:
print('输入错误,请重新输入。')
string formating字符串格式化,function函数,group组,recursion递归,练习的更多相关文章
- Python第二天 变量 运算符与表达式 input()与raw_input()区别 字符编码 python转义符 字符串格式化 format函数字符串格式化 帮助
Python第二天 变量 运算符与表达式 input()与raw_input()区别 字符编码 python转义符 字符串格式化 format函数字符串格式化 帮助 目录 Pychar ...
- string.Format字符串格式化说明(转)
string.Format字符串格式化说明 www.111cn.net 编辑:Crese 来源:转载 先举几个简单的应用案例: 1.格式化货币(跟系统的环境有关,中文系统默认格式化人民币,英文系统 ...
- 通过Oracle函数SQL实现C# String.Format字符串格式化功能
语言国际化要求,开发上要求Oracle数据库SQL中对应的返回信息-Message,实现一个通用函数调用,比如:提示信息内容:条码123456当前工站在FCT!”,即通用的信息内容格式化标准为:“条码 ...
- 【笔记】Python基础二:数据类型之集合,字符串格式化,函数
一,新类型:集合 集合出现之前 python_l = ['lcg','szw','zjw'] linux_l = ['lcg','szw','sb'] #循环方法求交集 python_and_linu ...
- Python3之字符串格式化format函数详解(上)
概述 在Python3中,字符串格式化操作通过format()方法或者f’string’实现.而相比于老版的字符串格式化方式,format()方法拥有更多的功能,操作起来更加方便,可读性也更强.该函数 ...
- Python: 字符串格式化format()函数的使用
python从2.6开始支持format,新的更加容易读懂的字符串格式化方法,从原来的% 模式变成新的可读性更强的 花括号声明{}.用于渲染前的参数引用声明, 花括号里可以用数字代表引用参数的序号, ...
- Day5 双层装饰器、字符串格式化、生成器、迭代器、递归
双层装饰器实现用户登录和权限认证 #!/usr/bin/env python# -*- coding: utf-8 -*-# Author: WangHuafeng USER_INFO = {} de ...
- python3字符串格式化format()函数的简单用法
format()函数 """ 测试 format()函数 """ def testFormat(): # format()函数中有几个元素, ...
- string.Format字符串格式化说明
1.格式化货币(跟系统的环境有关,中文系统默认格式化人民币,英文系统格式化美元) string.Format("{0:C}",0.2) 结果为:¥0.20 (英文操作系统结果:$0 ...
随机推荐
- POJ-3294 Life Forms n个字符串中出现超过n/2次的最长子串(按字典序依次输出)
按照以前两个字符串找两者的最长公共子串的思路类似,可以把所有串拼接到一起,这里为了避免讨论LCP跨越多个串需需要特别处理的问题用不同的字符把所有串隔开(因为char只有128位,和可能不够用,更推荐设 ...
- RMAN 的优缺点及RMAN 备份及恢复步骤
一. RMAN 备份的一些优点和OS命令备份方式相比,使用RMAN的优点 1 备份执行期间不需要人工干预,因此减少了误操作的机会:2 可以有效的将备份和恢复结合起来:3 支持除逻辑备份以外的所有 ...
- mysql5.5大数据量下表结构升级
升级一张4万多行(增加一个字段),且包含blob字段的表(blob字段包含100KB左右的数据),运行alter语句:ALTER TABLE `imgdetail` ADD COLUMN `uplo ...
- exadata cellcli
cellcli [port_number] [-n] [-m] [-xml] [-v | -vv | -vvv] [-x] [-e command] The following table lists ...
- Spring Security 案例实现和执行流程剖析
Spring Security Spring Security 是 Spring 社区的一个顶级项目,也是 Spring Boot 官方推荐使用的安全框架.除了常规的认证(Authentication ...
- [BZOJ1406]密码箱
Problem 给你1个数n,求出0 ≤ x < n,并且x ^ 2 % n = 1 Solution x ^ 2 - 1 = kn,(x - 1) * (x + 1) = kn 所以枚举n的约 ...
- tensorFlow(六)应用-基于CNN破解验证码
TensorFlow基础见前博客 简介 传统的验证码识别算法一般需要把验证码分割为单个字符,然后逐个识别.本教程将验证码识别问题转化为分类的问题,实现对验证码进行整体识别. 步骤简介 本教程一共分为四 ...
- C#设置随机整数
JQuery var x = 5;//最大值var y = 1;//最小值var rand = parseInt(Math.random() * (x - y + 1) + y); Mvc控制器 Ra ...
- window配置 mysql 详细步骤
1.配置环境变量:右击“我的电脑”-->"高级"-->"环境变量" 3)在(系统变量)path变量(已存在不用新建)添加变量值:G:\MySQL\m ...
- 禁止WORDPRESS站内搜索的方法
如果我们希望禁止站内搜索,毕竟会是的MYSQL负担加重,我们可以禁止掉,然后在使用第三方搜索组件.比如用百度站内搜索或者360站内搜索. function fb_filter_query( $quer ...