# day9

# 1.什么是集合(set)
# 1)集合是容器型数据类型:将{}作为容器的标志,里面多个元素用逗号隔开:{元素1,元素2,元素3,.....}
# 2)可变的;无序的
# 3)元素的要求:
# a.必须是不可变类型的数据
# b.元素是唯一的(自动去重)
# 空集合
s1=set()
print(type(s1))
#集合无序
print({10,20,30}=={30,20,10})
#元素是不可变类型的数据
s2={10,'abc',23.9,(1,2)}
print(s2)
#  s3={10,‘abc’,[1,2]}报错!列表是可变数据不能作为集合元素
# 元素是唯一的
s4={10,10,20,30,10,20}
print(s4)
# 增删改查(了解)
# 1)查-只能遍历
s5={29,80,55,45}
for x in s5:
    print('x:',x)
# 2)增
# 集合.add(元素)  -  将元素添加到集合中
s5.add(100)
print(s5)
# 3)删
# 集合.remove(元素)  -  删除指定元素,元素不存在就报错
# 集合.discard(元素) -  删除指定元素,元素不存在就不报错
s5.remove(80)
print(s5)
# 4)改 -  没有改的语法,如果要改就删除原来的再添加
# 数学集合运算
# python中的集合支持数学集合运算:并集(i)、交集(&)、差集(-)、对称差集(^)、子集(>= <=)、真子集(><)
A={1,2,3,4,5,6,7,}
B={5,6,7,8,9,10}
# 1.并集(|)
# 集合1|集合2  -  将两个集合合并产生一个新的集合
print(A|B)
#2.交集(&)
# 集合1&集合2 -  获取两个集合公共部分产生一个新的集合
print(A&B)
# 3.差集(-)
# 集合1-集合2  -  获取集合1中没有包含在集合2中的元素,得到一个新的集合
# 集合2-集合1   - 获取集合2中没有包含在集合1中的元素,得到一个新的集合
print(A-B)
print(B-A)
#4.对称差集
# 集合1 ^集合2 - 两个集合合并去掉公共部分
print(A^B)
#5.子集和真子集
# 集合1 >= 集合  - 判断集合2是否是集合1的子集
# # 集合1<= 集合2   - 判断集合1是否是集合2的子集
# 集合1 > 集合  - 判断集合2是否是集合1的真子集
# 集合1< 集合2   - 判断集合1是否是集合2的真子集
print({1,2,3}>{0})
print({1,2,3}>{1})
# 字符串
#1.什么是字符串(str)
#字符串是容器型数据类型
# 字字符串不可变;字符串有序
# 字符串元素:引号中的每一个符号都是字符串的元素,又叫字符
# 字符分为普通字符和转义字符两种:
# 普通字符  -  在字符串中表示符号本身的字符
# ''"、"""""""、''''''作为容器的标志,里面的每一个符号就是它的一个元素
#三个引号开头的字符串,字符串内容可以直接换行
str1='abc'
str2="abc"
str3="""123
abc"""
str4='''123
abc'''
print(str1,str2,str3,str4)
#2)字符 - 字符串的元素
# 普通字符
str5='afas'
str6='12f'
str7='数据'
str8='❀'
print(str8)
#转义字符   -  在特定的一些符号前
str9='bc\n1235\t00'
print(str9)
#字符串有序
print('abc'=='cba')
#字符和字符编号
# 常用的转义字符
# 1.转义字符
# \n  -  换行(相当于按回车)
# \t -  水平制表符(相当于按tab键)
# \'   -  一个普通的单引号
# \"  -  一个普通单引号
# \  -  一个普通的反斜杠
# \u4位的16进制数 -  编码字符
print('\tabc')
print("It's OK")
print('It\'s OK')
str="I say:\"sd  df  dsfs  ds\""
print(str)
path='C:\用户\\test\\name\huangpeng\a.txt'
#2)R语法
#如果在字符串的最前面加或者R可以让字符串所有的转义字符功能消失,每个符号都会变成普通字符
c=r'\34\324\na'
c1=R'43\443\t\n'
print(c,c1)
# 字符编号
# 1.计算机存储数据的原理
# 计算机只具备存储数字的能力
#2.字符编码
# 为了能够让计算机存储文字信息,给每一个符号对应了一个固定的数字,每次需要存储文字符号的时候就存储这个符号对应的数字
# 这个数字就是这个符号编码值
# 3.编码表  -  保存不同字符对应的编码的表
# 1)ASCII码表
# 128符号(美国符号)
# 数字在大写字母的前面,大写字母在小写字母前面,大写字母和小写字母之间有间隙
# 2)Unicode编码表(python)
#Unicode编码表包含了ASCII码
#Unicode包含了世界上所有的国家所有的民族的所有符号,万国码
# 中文:4e00~9fa5
# 4.python对编码值的使用
# 1)chr(函数)
# chr(编码值) --  获取数字对应的字符
# print(chr(2000))
# print(chr(0x9e00))
# num=0
# for x in range(0x4e00,0x9fa5+1):
#     print(chr(x),end='')
#     num+=1
#     if num%30==0:
#         print()
# print(num)
# 2)ord(函数)
# ord(字符) - 获取字符对应的编码值
print(ord('黄'),ord('鹏'))
# 3)编码字符
# \u4的16进制数  - 创建一个字符,字符就是4的16进制作为编码值对应的字符
str1='\u0061\u4f59\u5a77'
print(str1)
x='好'
print('\u4e00' <= x <='\u9fa5')
# 进制
# 数字常见的表示方式有4种:二进制、八进制、十进制、十六进制
# 1.十进制
# 基数:0,1,2,3,4,5,6,7,8,9
# 表现方式:直接写
# 转换方式:print(其他进制的数)
print(10,123)
print(0o12)  #8进制转换为10进制数打印出来
# 2.二进制
# 基数:0,1
# 表示方式:加前缀0b、0B
# 转换方法:bin(其他进制的数)
print(bin(12))
#3.八进制
# 基数:0、1、2、3、4、5、6、7
# 表示方式:加前缀0o、0O
# 转换方式:oct(其他进制的数据)
print(0o56)
# 4.十六进制
# 基数:a、b、c、d、e、f(可大写)
# 表现方式:加前缀0x、0X
# 转换方式:hex(其他进制的数)
print(0xabc)
print(chr(28291))
print('\u6e83')
# 字符串作为容器的操作
# 字符串不可变,所以支持查操作
# 1.查  -  获取字符
# 字符串获取字符和列表获取元素的对应的语法一模一样的
str1='abc123'
print(str1[2],str1[-4])
print(str1[1:])
print(str1[1:-1:2])
print(str1[3:1:2])
for x in str1:
    print('x:',x)
# 每一个有效转义字符的长度都是1
str2='\tBC\n123\\'
print(str2[1])
print(str2[3])
str3=r'\23\43\gr\54\n43\\'
print(str3[2])
print(str3[9])
# 2.in 和 not in
# 字符串1 in 字符串2  -  判断字符串2中是否包含字符串1(判断字符串1是否是字符串2的子串)
print('ab' in 'abc')
print('a' in 'abc')
print('ab' in 'acb')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值