python基本数据类型操作
str 字符串
#1.进行字符串转换 首字母转换成大写
# name = 'wangjianhui'
# v = name.capitalize()
# print(v) #2. 字符转换小写
# name = 'WangJianHui' #将所有的字符串转换成小写 包括多种语言
# v = name.casefold()
# print(v)
# name = 'WangJianHui' #将所有字符转换成小写,只限于英文
# v = name.lower()
# print(v) #3 填充空白
# name = 'wangjianhui' #填充空白 将字符串内容居中
# v = name.center(50,'*')
# print(v) #4 查询索引
# name = 'wangjianhui123321' 查询出现字符的次数
# v = name.count('1')
# v = name.count('wang',0,15)指定查询位置以某索引开始到某索引结束
# print(v) #5查询是否已某字段开始或结束
# name = 'wangjianhui'
# v = name.endswith('hui')
# print(v)
# v = name.startswith('wang') #6 找到制表符\t,进行替换(包含前面的值)
# name = 'name:\twangjianhui\nage:\t19'
# v = name.expandtabs(10)#
# print(v) #7 查询索引位置
# name = 'wangjianhui'
# v = name.index('w') 字符串中不存在的内容 查找会报错
# print(v)
# v = name.find('w') 字符串不存在的内容 查找返回-1
# print(v) #8 字符串格式化方法
# infomesion = 'name:%sage:%sjob:%s' %s占位符
# print(infomesion%('wangjianhui',19,'it')) # infomesion = 'name:{0};age:{1};job{2}' format方法
# v = infomesion.format('wangjianhui',19,'it')
# print(v)
# infomesion = 'name:{name};age:{age};job{nianling}'
# v = infomesion.format(name='wangjianhui',age=19,nianling='it')
# print(v) # infomesion = 'name:{name};age:{age};job{nianling}' format_map 以字典的形式进行填充
# v = infomesion.format_map({'name':'wangjianhui','age':19,'nianling':'it'})
# print(v) #9字符串内容进行判断
#是否是数字、汉字不能包含特殊符号
# name = 'wangjianhui男子汉1'
# v = name.isalnum()
# print(v)
#判断是否是数字
# name = '②'
# v1 = name.isdecimal() #只能判断是否为阿拉伯数字
# v2 = name.isdigit() #特殊数字如②也可识别
# v3 = name.isnumeric()#阿拉伯数字及② 二都可识别
# print(v1,v2,v3) #10
#判断是否是标识符
# name = 'wangjianhui'
# v = name.isidentifier()
# print(v) #11
#判断是否全部是小写
# name = 'WangJianHui'
# v1 = name.islower()
# v2 = name.isupper()
# print(v1,v2) #12
#全部变大写 对应全部小写lower
# name = 'wangjianhui'
# v = name.upper()
# print(v) # 13
# 是否包含隐含的xx
# name = "钓鱼要钓刀鱼,\n刀鱼要到岛上钓"
# v = name.isprintable()
# print(v) # 14
# 是否全部是空格
# name = ' '
# v = name.isspace()
# print(v) #15
#内部循环每个元素
# name = 'wangjianhui'
# v = '_'.join(name)
# print(v)
# name = ['王建辉','金丽珍']
# v = '爱'.join(name)
# print(v) #16
#字符替换
# name = 'aleX'
# v = name.replace('l','p')
# print(v) #17
#转换字节类型
# name = '王建辉'
# v1 = name.encode(encoding='utf-8')
# v2 = name.encode(encoding='gbk')
# print(v1,v2) #18左右填充
# center,rjust,ljust
# name = 'wangjianhui'
# v = name.ljust(20,'*')
# print(v) #19对应关系加翻译
# m = str.maketrans('wangjianhui','123456')
# name = 'wangxiaoerweqrrwrwrq;wfasfs'
# v = name.translate(m)
# print(v) #20保留分割的元素
# content = "李泉SB刘康SB刘浩SB刘一"
# v = content.replace('SB','Love')
# print(v)
# v = content.replace('SB','Love',1) 指定几个字符替换
# print(v) # 21,移除空白,\n,\t,自定义
# name = 'alex\t'
# v = name.strip() # 空白,\n,\t
# print(v) # 22. 大小写转换
# name = "Alex"
# v = name.swapcase()
# print(v) #23填充0
# name = 'wangjianhui'
# v = name.zfill(30)
#
# name1 = 'wangjianhui1'
# v = name + name1
# print(v) ###### 字符串功能总结:
# name = 'alex' 创建字符串给变量 或str()
# name.upper() 转换为大写
# name.lower()转换为小写
# name.split() 切割
# name.find() 查找索引 没有不会报错
# name.strip() 移除空白或指定符号
# name.startswith()以什么内容开始
# name.format() 表格填充
# name.replace() 保留分割元素替换
# "alex".join(["aa",'bb']) 添加分割 ###### 额外功能:
# name = "alex"
# name[0]
# name[0:3]
# name[0:3:2]
# len(name)
# for循环,每个元素是字符
# for i len(name):
# print(name[i])
int 整数
#1. 获取当前数值二进制最小位数
# name = 10
# v = name.bit_length()
# print(v) #2.获取当前数据的字节表示
# name = 15
# v = name.to_bytes(5,byteorder='big') #位数表示 从后往前正常显示
# v1 = name.to_bytes(5,byteorder='little')#从前往后反向显示
# print(v,v1)
bool 布尔值
#1. False True
#0为False 1或其他为True
# print(bool(0))
list 列表
# user_list = ['李泉','刘一','刘康','豆豆','小龙'] # 可变类型
# PS:
#功能集合
#1.追加 append
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# user_list.append('王二')
# print(user_list) #2.清空 clear
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# user_list.clear()
# print(user_list) #3.拷贝 浅拷贝copy
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# user_list1 = user_list.copy()
# print(user_list1) #4.计数 统计某个列表字符数量 count
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# user_c = user_list.count('小龙')
# print(user_c) #5.扩展列表 extend
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# user_list.extend(['王建辉','王二小'])
# print(user_list) #6.查找元素索引,没有则报错 index
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# v = user_list.index('小龙')
# print(v) #7.删除 pop(按照索引删除,并保存删除值) remove(指定删除内容不保存) del(索引删除不保留)
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# v = user_list.pop(1)
# print(v,user_list) # del user_list[1]
# print(user_list) # user_list.remove('李泉')
# print(user_list) #8.列表翻转 reverse
# user_list = ['李泉','刘一','刘康','豆豆','小龙']
# user_list.reverse()
# print(user_list) #9.排序 sort
#user_list = [1,'李泉','刘一','刘康','豆豆','小龙']#数字和字符不能进行排序
# user_list = [10,20,5,67,44]
# user_list.sort() #从小到大
# print(user_list)
# user_list.sort(reverse=True/False) 从大到小或从小到大
# print(user_list) #10. ###### 额外:
# user_list = ['李泉','刘一','李泉','刘康','豆豆','小龙']
# user_list[0]
# user_list[1:5:2] #显示从索引开始结束 跳着显示
# del user_list[3]
# for i in user_list: #循环显示
# print(i)
# user_list[1] = '姜日天' 覆盖或修改
# user_list = ['李泉','刘一','李泉','刘康','豆豆',['日天','日地','泰迪'],'小龙'] #嵌套
range,enumrate
# 1. 请输出1-10
# 2.7: 立即生成所有数字
# range(1,11) # 生成 1,23,,4,56.10 # 3.x: 不会立即生成,只有循环迭代时,才一个一个生成
# for i in range(1,11): #
# print(i) # for i in range(1,11,2): #
# print(i) # for i in range(10,0,-1): #
# print(i) # 2. range: 三个参数
#
# li = ['eric','alex','tony']
# # range,len,li循环
# for i in range(0,len(li)):
# ele = li[i]
# print(ele) # li = ['eric','alex','tony']
# for i in li:
# print(i) # for i in range(0,len(li)):
# print(i+1,li[i]) # enumerate额外生成一列有序的数字
# li = ['eric','alex','tony']
# for i,ele in enumerate(li,1):
# print(i,ele)
#
# v = input('请输入商品序号:')
# v = int(v)
# item = li[v-1]
# print(item)
tuple:元组,不可被修改的列表;不可变类型
#创建元组
#name = ('wnagjianhui','wangxiaoer','wangerxiao')
#1.获取元祖字符个数
# name = ('wangjianhui','wangxiaoer','wangerxiao')
# v = name.count('wangjianhui')
# print(v) #2.获取索引位置
# name = ('wangjianhui','wangxiaoer','wangerxiao')
# v = name.index('wangjianhui')
# print(v) #3.额外
# user_tuple = ('alex','eric','seven','alex')
# for i in user_tuple:
# print(i) # v = user_tuple[0] # v = user_tuple[0:2]
# print(v) # user_tuple = ('alex','eric','seven',['陈涛','刘浩','赵芬芬'],'alex')
# user_tuple[0] = 123 x
# user_tuple[3] = [11,22,33] x
# user_tuple[3][1] = '刘一'
# print(user_tuple) # li = ['陈涛','刘浩',('alex','eric','seven'),'赵芬芬']
# ****** 元组最后,加逗号 ******
# li = ('alex',)
# print(li)
dict:字典: 可变类型
#1.清空字典 clear
# namedic = {'name':'wangjianhui','age':19,'job':'it'}
# namedic.clear()
# print(namedic) #2.浅拷贝 copy
# namedic = {'name':'wangjianhui','age':19,'job':'it'}
# namedic1 = namedic.copy()
# print(namedic1) #3.根据key值获取value值,不存在不报错 get
# namedic = {'name':'wangjianhui','age':19,'job':'it'} get查找根据key找value 找不到不报错
# namedic1 = namedic.get('name')
# print(namedic1) #4.删除key对应的value值 并保存删除值
# namedic = {'name':'wangjianhui','age':19,'job':'it'}
# namedic1 = namedic.pop('name')
# print(namedic1,namedic) # 5. 随机删除键值对,并获取到删除的键值 popitem
# dic = {'k1':'v1','k2':'v2'}
# v = dic.popitem()
# print(dic)
# print(v) # v = dic.popitem() # ('k2', 'v2')
# print(dic)
# print(v[0],v[1]) #6.增加字典 如果存在则不作操作
# namedic = {'name':'wangjianhui','age':19,'job':'it'}
# namedic.setdefault('wait','1111')
# print(namedic) #7.批量增加或修改
# namedic = {'name':'wangjianhui','age':19,'job':'it'}
# namedic.update({'name':'wangxiaoer','wait':'111'})
# print(namedic) #8.批量创建字典
# dic = dict.fromkeys(['k1','k2','k3'],321)
# print(dic) # ########## 额外:
# - 字典可以嵌套
# - 字典key: 必须是不可变类型
# dic = {
# 'k1': 'v1',
# 'k2': [1,2,3,],
# (1,2): 'lllll',
# 1: 'fffffffff',
# 111: 'asdf',
# }
# print(dic)
# key:
# - 不可变
# - True,1 # dic = {'k1':'v1'}
# del dic['k1']
set集合
# s1 = {"alex",'eric','tony','李泉','李泉11'}
# s2 = {"alex",'eric','tony','刘一'}
# 1.s1中存在,s2中不存在
# v = s1.difference(s2)
# print(v)
# #### s1中存在,s2中不存在,然后对s1清空,然后在重新复制
# s1.difference_update(s2)
# print(s1) # 2.s2中存在,s1中不存在
# v = s2.difference(s1)
# print(v) # 3.s2中存在,s1中不存在
# s1中存在,s2中不存在
# v = s1.symmetric_difference(s2)
# print(v)
# 4. 交集
# v = s1.intersection(s2)
# print(v)
# 5. 并集
# v = s1.union(s2)
# print(v) # 6. 移除
# s1 = {"alex",'eric','tony','李泉','李泉11'}
# s1.discard('alex')
# print(s1) # s1 = {"alex",'eric','tony','李泉','李泉11'}
# s1.update({'alex','123123','fff'})
# print(s1)
# ##### 额外: # s1 = {"alex",'eric','tony','李泉','李泉11'}
# for i in s1:
# print(i) # s1 = {"alex",'eric','tony','李泉','李泉11',(11,22,33)}
# for i in s1:
# print(i)
python基本数据类型操作的更多相关文章
- python基础之数据类型操作补充,集合及其操作,深浅拷贝
内容概要: 数据类型操作补充 集合及其操作 深浅拷贝1.基础数据类型补充 1.1字符串的操作补充li = ["李嘉诚", "麻花藤", "黄海峰&qu ...
- Python数据分析与展示[第三周](pandas数据类型操作)
数据类型操作 如何改变Series/ DataFrame 对象 增加或重排:重新索引 删除:drop 重新索引 .reindex() reindex() 能够改变或重排Series和DataFrame ...
- python高级之操作数据库
python高级之操作数据库 本节内容 pymysql介绍及安装 使用pymysql执行sql 获取新建数据自增ID fetch数据类型设置 1.pymysql介绍及安装 在python2中连接数据库 ...
- python常用数据类型内置方法介绍
熟练掌握python常用数据类型内置方法是每个初学者必须具备的内功. 下面介绍了python常用的集中数据类型及其方法,点开源代码,其中对主要方法都进行了中文注释. 一.整型 a = 100 a.xx ...
- 第九篇:python高级之操作数据库
python高级之操作数据库 python高级之操作数据库 本节内容 pymysql介绍及安装 使用pymysql执行sql 获取新建数据自增ID fetch数据类型设置 1.pymysql介绍及 ...
- python基本数据类型之整型和浮点型
python基本数据类型之数字与浮点型 在python3中,整数的数据类型为int,而浮点数的数据类型为float.python2中整数可以是int和long(长整型)两种类型,python3只保留了 ...
- Python的数据类型和运算
一.Python数据类型 变量所指向的值是有自己独特的数据类型的,这些数据类型可能代表不同的数据,在Python中,主要有以下几种数据类型: 整形(int) 在计算机中,整数的位数其实是有范围的,并没 ...
- Python基础数据类型-列表(list)和元组(tuple)和集合(set)
Python基础数据类型-列表(list)和元组(tuple)和集合(set) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的 ...
- Python基础数据类型-字符串(string)
Python基础数据类型-字符串(string) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版 ...
随机推荐
- charles中Map、Rewrite、Breakpoints的区别
Charles提供了Map功能.Rewrite功能.Breakpoints功能,都可以达到修改服务器返回内容的目的,这三者的差异是: Map Map功能适合长期的将某些请求重定向到另一个网络地址或本地 ...
- AT4353-[ARC101D]Robots and Exits【LIS】
正题 题目链接:https://www.luogu.com.cn/problem/AT4353 题目大意 数轴上有\(n\)个球\(m\)个洞,每次可以将所有球左移或者右移,球到洞的位置会掉下去. 求 ...
- CF622F-The Sum of the k-th Powers【拉格朗日插值】
正题 题目链接:https://www.luogu.com.cn/problem/CF622F 题目大意 给出\(n,k\),求 \[\sum_{i=1}^ni^k \] 解题思路 很经典的拉格朗日差 ...
- MySQL的本地事务、全局事务、分布式事务
本地事务 事务特性:ACID,其中C一致性是目的,AID是手段. 实现隔离性 写锁:数据加了写锁,其他事务不能写也不能读. 读锁:数据加了读锁,其他事务不能加写锁可以加读锁,可以允许自己升级为写锁. ...
- java文件上传工具包
java 文件上传工具包 主要有两个方法:单文件上传和多文件上传 @Slf4j public class UploadFileUtil { //上传单张图片 public String uploadP ...
- 浅析InnoDB引擎的索引和索引原理
浅析InnoDB引擎的索引和索引原理 什么是InnoDB的索引 InnoDB的索引就是一颗B+树.页是InnoDB引擎在内存和磁盘之间交换数据的基本单位,页的大小一般是16KB,页的大小可以在启动My ...
- 题解 「HDU6403」卡片游戏
link Description 桌面上摊开着一些卡牌,这是她平时很爱玩的一个游戏.如今卡牌还在,她却不在我身边.不知不觉,我翻开了卡牌,回忆起了当时一起玩卡牌的那段时间. 每张卡牌的正面与反面都各有 ...
- 编程模仿MySql客服端
写在前面 通过自己编写的Java代码程序,去模仿实现MySql客服端的简单功能,最终以控制台操作,很像在Dos窗口通过命令操作MySql数据库. 关键问题 在编写过程中遇到的一些小问题和一些值得留心注 ...
- python中冒泡排序代码实现
1.冒泡排序代码如下图: #冒泡算法l=[12,4,56,10,6,2]for i in range(0,6): for j in range(i+1,6): if l[i]>l[j]: a=l ...
- Linux 命令后&的作用
cp $filename /dev/ & & 代表非阻塞方式拷贝文件,如果不加& 则必须等到执行完该指令后才能执行后来的指令.