Py集合,字符串的格式化,函数,便利
可变与不可变
不可变指的是:重新赋值时,内存中的id值会变得
其中有:字符串,数字,元组
name="sb"
v=id(name)
print(v)
name ="alex"
v1 =id(name)
print(v1)
可变指的是:重新赋值时,内存中的id值不会变得
其中有列表,字典
hobby=["code","play"]
v=id(hobby)
print(v)
hobby[0]="123"
m=id(hobby)
print(m)
数据类型:集合
属性:由不同的元素组合,集合中的元素必须是不可变型(字符串或数字或元组)
定义方法:
s={1,2,2,3,3,3,"ab"}
print(s)
输出后重复的会被去掉,因为集合是由不同元素组合的
可以通过函数创建集合set()
s=set("hello")
print(s)
1.在末尾添加元素add()
2.清空clear()
3.拷贝copy()
4. 随机删除一个元素pop()
5.指定删除某个元素remove(),如果指定删除的元素没有则会报错
s={"sb",1,12,2,3}
s.remove("sb")
print(s)
5.指定删除某个元素discard(),如果指定删除的元素没有不会报错
s={"sb",1,12,2,3}
s.discard("sbb")
print(s)
6.列表转换成集合set()
pyl=["11","22","##","11"]
lsl =[22,"ppp"]
ps1=set(pyl)
ps2=set(lsl)
print(ps1,ps2)
7.求两个集合的交集intersection()
pyl=["11","22","##","11"]
lsl =["22","ppp"]
ps1=set(pyl)
ps2=set(lsl)
print(ps1.intersection(ps2))
print(ps1&ps2)
8.求两个集合的并集union()
pyl=["11","22","##","11"]
lsl =["22","ppp"]
ps1=set(pyl)
ps2=set(lsl)
print(ps1.union(ps2))
print(ps1|ps2)
8.求两个集合的差集difference(),差集表示前面这个集合有的后面的那个集合没有的
pyl=["11","22","##","11"]
lsl =["22","ppp"]
ps1=set(pyl)
ps2=set(lsl)
print(ps1.union(ps2))
print(ps1|ps2)
9.交叉补集(把两个集合先和到一块,再去掉两者共有的部分)symmetric_difference()
第一个集合,symmetric_difference(第二个集合)
可用于:有两门课,找出其中只报了一门课的人
10.差集再更新,求完差集后赋值给前面的集合difference_update()
pyl=["lcg","scw","zjw","lcg"]
lnl=["lcg","scw","sb"]
p_s = set(pyl)
l_s = set(lnl)
p_s.difference_update(l_s)
print(p_s)
11.判断集合是否没有交集isdisjoint()
pyl=["lcg","scw","zjw","lcg"]
lnl=["lcg","scw","sb"]
p_s = set(pyl)
l_s = set(lnl)
p_s.difference_update(l_s)
print(p_s)
12.判断一个是不是另一个的子集issubset()
s1={1,2}
s2={1,2,3}
print(s1.issubset(s2))
print(s2.issubset(s1))
13.判断是不是父集issuperset()
14.求并集后赋值给前面的那一个集合update()
s1={1,2}
s1.update({15,4,3})
print(s1)
可以一次更新多个值
15.建立不可修改的集合frozenset()
s=frozenset("hrllo")
print(s)
字符串的格式化
字符串的拼接
百分号代表格式化,s代表字符串类型
%s代表此处填入字符串,如果只截取前两位%.2s
%d表示整型数字
%f表示浮点小数,如果只取两位小数%.2f(会自动四舍五入)
要打印出百分号需要输入两个百分号%%
print("i am %s my hobby is abcd" %"ewq")
print("i am"+" ewq "+"my hobby is abcd")
print("i am %s my hobby is %s" %("ewq","shit"))
左对齐(-)
print("i am %-60s my hobby is abcd" %"ewq")
右对齐(+)
print("i am %-60s my hobby is abcd" %"ewq")
在一段中间插入相同的字符串
print("user",'asd','ddd',sep=':')
使用format传送值
不按顺序传
tpl = "i am {2},age {1},{0}".format("seven",18,"alex")
print(tpl)
按照名字来传
tpl = "i am {name},age {age},{value}".format(name="seven",age=18,value="alex")
print(tpl)
用字典来传(字典前面加两颗星星)
tpl = "i am {name:s},age {age:d},{value}".format(**{"name":"seven","age":18,"value":"alex"})
print(tpl)
用列表来传(列表前面加一颗星)
tpl = "i am {:s},age {:d}".format(*["seven",18])
print(tpl)
用星号引用(便利)另一个指针的
l=['seven',18]
tpl = "i am {:s},age {:d}".format(*l)
print(tpl)
:b代表二进制 :o代表八进制 :d代表整形 :x代表十六进制(字母部分小写) :X代表十六进制
(字母部分大写) :%代表显示百分比(带六位的小数)。
tpl = "number : {:b},{:o},{:d},{:x},{:X},{:%}".format(15,15,15,15,15,15.87652,2)
print(tpl)
函数:
1.定义方法
def test(x):
"函数注释"
y=2*x+1
return y
feedback=test(3)
print(feedback)
2.test如果没有自变量就直接test()
3.如果函数重名,调用的将是最新最下面的那一个函数
函数与过程
函数是逻辑结构化的一种编程方法,包含返回值return的
过程是逻辑结构化的一种编程方法,没有返回值return的
如果return返回的是多个值,那它返回的那些值会拼接成一个元组
def calc(x,y):
res=x**y
return res
c = calc(a,b)
print(c)
这个程序里面的xy是形参,ab是实参。**代表求平方
形参是不占据内存空间的,当被赋值时才占据空间
def calc(x,y):
res=x**y
return res
a= input("请输入底数")
b= input("请输入次方")
c = calc(int(a),int(b))
print(c)
函数里面的参数的子项的顺序可以不按顺序,但是个数不能多 也不能少
def printabcd(x,y,z):
print(x)
print(y)
print(z)
printabcd(z=1,y=3,x=2)
默认参数
以下的type为默认参数
def handle(x,type='mysql'):
print(x)
print(type)
handle('hello')
当然默认参数也是可以被赋值的
def handle(x,type='mysql'):
print(x)
print(type)
handle('hello','abce')
参数组:字典前面加**,元组前面加*
def test(x,*args):
print(x)
print(args)
test(1,2,3,4,5,6)
def test1(x,**kargs):
print(x)
print(kargs)
test1(1,y=2,z=3)
*的具体意义是便利,比如*(1,2,3,4,5,6)就是用for逐个将123456分开传,而不是以一个整体传
Py集合,字符串的格式化,函数,便利的更多相关文章
- php对字符串的操作4之 字符串的格式化函数
strtolower($str ) strtoupper($str ) 大小写转换 strtotime('2018-1-1 0:0') 字符串转时间戳 date('Y-m-d H:i:s',time( ...
- pyextend库-unpack列表集合字符串解包函数
pyextend - python extend lib unpack (iterable, count, fill=None) 参数: iterable: 实现 __iter__的可迭代对象, 如 ...
- python字符串的格式化
# -*- coding:utf-8 -*- """ @Author:janson @Date:2018/8/1 @File:StrFormat.py "&qu ...
- #微码分享#C++变参字符串格式化函数format_string
在C和C++中,变参格式化函数虽然非类型安全,但却十分便利,因为得到广泛使用.对于常见的size_t类型要用“%zu”,ssize_t用”%zd“,int64_t用“% ”PRId64,uint64_ ...
- 关于jqGrig如何写自定义格式化函数将JSON数据的字符串转换为表格各个列的值
首先介绍一下jqGrid是一个jQuery的一个表格框架,现在有一个需求就是将数据库表的数据拿出来显示出来,分别有id,name,details三个字段,其中难点就是details字段,它的数据是这样 ...
- PHP中常用的字符串格式化函数总结
注意:在PHP中提供的字符串函数处理的字符串,大部分都不是在原字符串上修改,而是返回一个格式化后的新字符串. 一.取出空格和字符串填补函数 空格也是一个有效的字符,在字符串中也会占据一个位置.用户在表 ...
- [PostgreSQL]PostgreSQL数据类型格式化函数——字符串和数值间的转换
详情见官网:http://www.postgres.cn/docs/10/functions-formatting.html PostgreSQL中有以下格式化函数: 函数 返回类型 描述 例子 to ...
- sql常用格式化函数及字符串函数
一.常用格式化函数 1.日期转字符串 select to_char(current_timestamp, 'YYYY-MM-DD HH24:MI:SS') YYYY:年份 MM:月份号(01-12) ...
- php课程 6-22 字符串格式化函数有哪些(精问)
php课程 6-22 字符串格式化函数有哪些(精问) 一.总结 一句话总结: 1.猜测一下$_GET()怎么来的? 函数赋值给变量的操作:$_YZM=get(); 这样就可以很好的解释哪些全局变量 ...
随机推荐
- Python高级语法-GIL-理解(4.1.1)
@ 目录 1.结论 2.代码 关于作者 1.结论 当一个py文件执行多进程的时候,是真的在并发 当一个文件在使用多线程的时候,伪并发,在同一时刻只有一个线程执行,因为GIL Guido都说了,不好除这 ...
- 记录一下网上找到的别人写的angualr总结
感觉写的不错,所以讲链接保存下来 https://www.jianshu.com/p/f0f81a63cbcb
- 基于XGBoost模型的幸福度预测——阿里天池学习赛
加载数据 加载的是完整版的数据 happiness_train_complete.csv . import numpy as np import pandas as pd import matplot ...
- ⑦SpringCloud 实战:引入Sleuth组件,完善服务链路跟踪
这是SpringCloud实战系列中第7篇文章,了解前面第两篇文章更有助于更好理解本文内容: ①SpringCloud 实战:引入Eureka组件,完善服务治理 ②SpringCloud 实战:引入F ...
- Arduino PROGMEM 从程序空间读取float值的方法
方法: 使用avr-libc提供的宏定义: #define pgm_read_float_near(address_short) __LPM_float((uint16_t)(address_shor ...
- 7.自定义ViewGroup-下滑抽屉
1.效果 2.思路 分析效果: 1.布局分为两部分,后面部分,前面部分,默认状态后面被挡住: 2.后面不可以滑动,前面可以滑动: 3.如果前面的布局本身是可以滑动的,那么当前面布局滑动到第一个时,后面 ...
- java 的IO类库的基本架构
java IO 操作的类在java.io 包中,大概可以分为以下几组: 基于字节操作的接口:InputStream 和 OutputStream 基于字符操作的接口:Writer 和 Reader 基 ...
- [LeetCode]367. Valid Perfect Square判断完全平方数
方法有很多,我觉得比较容易记住的是两个,一个是二分法,在1-num/2中寻找目标数 另一个是数学方法: public boolean isPerfectSquare(int num) { /* 有很多 ...
- Linux嵌入式学习-交叉编译openssl
利用arm-none-linux-gnueabi-gcc交叉编译openssl,生成静态库文件libcrypto.a ,libssl.a 1.从openssl官网下载openssl最新版本,我下载的是 ...
- Access-Control-Allow-Headers等基础常识
跨源资源共享 (CORS) (或通俗地译为跨域资源共享)是一种机制,该机制使用附加的 HTTP 头来告诉浏览器,准许运行在一个源上的Web应用访问位于另一不同源选定的资源. 当一个Web应用发起一个与 ...