Python的基础类型(int,bool,str):
Python的基础类型(int,bool,str):
1.int -------> 整形:主要用力进行数字计算
2.string ------>字符串:可以保存少量数据并进行相关的操作
3.bool-------->布尔型:判断真假 true(真),false(假)
4.list--------->列表:存储大量数据,用[]来表示
5.tuple------->元组:不可以改变,用()表示
6.dict---------->字典:保存键值对,一样保存大量数据
7.ste----------->集合:保存大量数据不可以重复,也就是不保存value的dict
整数(int)
在Python中整数都是int型,但是在python2中如果数据量比较大.会使用long类型,在python3中不存在long类型,整数可以进行的操作
bit_length().计算整数在内存中占用的二进制长度
布尔值(bool):
取值只有ture和false,bool没有操作
转换问题:
str--------> int(str) str字符串类转换成数字类型
int-------->str(int) int数字类型转换成字符串类型
int--------->boot(int) int转换成布尔型,0是false,非0是true
bool------>int(bool) bool转换为数字类,true是1,fase是0,只存在1和0
str--------->bool(str) 空字符串是false,不空是true
bool------->str(bool) 把bool转成相应的值
元祖------->list(tuple) 把元祖转换成列表
列表------->tuple(list) 把列表转换成元祖
list------->str.join(list) 把列表转换成字符串
str-------> str.split() 把字符串切割为列表
转换成False的数据: 0,'',None,[],(),{},set() ==> False
字符串(str):
把字符连接到一起称作字符串:字符串是可以先加的:(字符串+字符串),在python中',",''',"""引起来的内容成为字符串
4.1:切片和索引
1.索引,索引就是下标记,切记,下标从0开始
- #
- name = "python最牛逼"
- print (name[0]) #获取p
- print (name[1]) #获取y
- print (name[2]) #获取t
- print (name[3]) #获取h
- print (name[4]) #获取o
- print (name[5]) #获取n
- print (name[6]) #获取最
- print (name[7]) #获取牛
- print (name[8]) #获取逼
- print (name[9]) #没有9,越界了会报错
- print(name[9])
- IndexError: string index out of range #索引错误:字符串索引超出范围
- print(name[-1]) #表示倒数第一个
- print(name[-2]) #表示倒数第二个
2.切片,我们可以使用下标来截取部分字符串内容
语法:str[start:end]
规则:顾头不顾尾,从start(开始)去截取,截取到end,最后一个则不截取
- name =python最牛逼
- print(name[0:3]) #从0获取到3,不包括3 结果:pyt
- print(name[6:8]) #从6获取到8,不包含8 结果:最牛
- print(name[6:9]) #最大是8,根据顾头不顾尾,想取到8必须给9 结果:最牛逼
- print(name[6:10]) #如果右边已经过了最大值,相当于取值到最后,切片超值不报错
- print(name[4:]) #从第4位取值到最后
- print(name[-1:-5]) #从-1到-5是获取不到结果的,因为从-1向右数,是数不到-5的
- print(name[-5:-1]) #从倒数第5个向右数,数到倒数第一个,结果on最牛
- print(name[-5:]) #从倒数第5个向右数,数到最后包括最后一位,结果:on最牛逼
- print(name[-1:]) #这个是取到最后一个,结果:逼
- print(name[:]) #原样输出
跳着截取
- #跳着取:步长
- name = "python最牛逼"
- print(name[1:5:2]) #从第一个开始取,取到第五个,每两个取一个 结果: yh, 分析: 1:5=> ytho => yh
- print(name[:5:2]) #从头开始到第五个. 每两个取一个
- print(name[4::2]) #从4开始取,取到最后,每两个取一个
- print(name[-5::2]) #从倒数第五个开始取到最后,每两个值娶一个
- print(name[-1:-5]) #-1到-5没有值,因为是从左往右取的
- print(name[-1:-5:-1]) #步长是-1,这时候就是从右往左取值
- print(name[-5::-3]) #从倒数第五个开始,到最开始,没3个值娶一个
步长:如果是整数,则从左往右,如果是负数从右往左数,默认是1
切片语法:str[start:end:step] start开始 end结束 step步长
4.2字符串的相关方法,字符串是不可变的对象,所以任何操作对原字符串是不会有影响的
1.大小写转来转去
- name = "i am a newbest"
- #capitalize
- print (name.capitalize()) #首字母大写,如果当前首字母为大写那么执行这个就变成小写
- #lower
- print (name.lower()) #全部转换为小写
- #upper
- print(name.upper()) #全部转换为大写
- #swapcase
- print(name.swapcase()) #大小写互相转换
- #casefold
- print (name.casefold()) # 转换成小写, 和lower的区别: lower()对某些字符支持不够好. casefold()对所有字母都有效. 比如东欧的一些字母
- #title
- print(name.title()) #每个被特殊字符隔开的首字母大写,中文也算是特殊字符
- #应用,身份验证输入验证码是否正确
- time = "zDxY"
- user1 = input("请输入验证码")
- if time.upper() == name.upper():
- print("验证成功")
- else:
- print("验证失败")
- name = "python最牛逼"
name.startswith() #大写转换小写,小写转换大写
name.title() #每个被特殊字符隔开的英文字母大写,中文也算是特殊符号
2.字符串切过来切过去
- #字符串是不可改变对象,所有操作都是产生新的字符串返回,如
- name = "xiao_liu_源"
- name.replace("xaio","liu")
- print (name) #结果xiao_liu_源,你会发现并没有改变
- print (name.replace("xaio","liu")) #结果liu_liu_源
- n1 = name.replace("xaio","liu")
- print (n1) #结果liu_liu_源
- ###############################################
- s5 = "周杰伦"
- name = s5.center(10,"*") #居中
- print (name) #结果:***周杰伦****
- #除去空格
- s7 = " xiao yao name "
- print(s7.strip()) #除去两边的空格
- print(s7.lstrip()) #除去左边的空格
- print(s7.rstrip()) #出去右边的空格
- #模拟用户登录,忽略用户输入空格
- user = input("请输入您的账户":)
- password = input("请输入您的密码")
- if user == alix and password == "":
- print("登陆成功")
- else:
- print("登陆失败")
- name = "111sdjshfkjsdh111"
- print (name.strip("")) #除去两边的111,可以指定元素
- #字符替换
- name = "xiao_dshk_jfhs_oming_dsjkfhsk_j"
- print (name.replace("xiao","liu")) #把xiao替换成liu
- print (name.replace("o","a",2)) #把两个o替换成a,name = "xiaa_dshk_jfhs_aming_dsjkfhsk_j"
- # 字符串切割
- s9 = "alex,wusir,sylar,taibai,eggon"
- lst = s9.split(",") # 字符串切割, 根据,进行切割
- print(lst)
- s10 = """诗人
- 学者
- 感叹号
- 渣渣"""
- print(s10.split("\n")) # 用\n切割,结果['诗人', '学者', '感叹号', '渣渣']
- # 坑
- s11 = "银王哈哈银王呵呵银王吼吼银王"
- lst = s11.split("银王") # ['', '哈哈', '呵呵', '吼吼', ''] 如果切割符在左右两端. 那么一定会出现空字符串.深坑请留意
- print(lst)
3.格式化输出:
- # 格式化输出
- s12 = "我叫%s, 今年%d岁了, 我喜欢%s" % ('sylar', 18, '周杰伦') # 之前的写法
- print(s12)
- s12 = "我叫{}, 今年{}岁了, 我喜欢{}".format("周杰伦", 28, "周润发") # 按位置格式化
- print(s12)
- s12 = "我叫{0}, 今年{2}岁了, 我喜欢{1}".format("周杰伦", "周润发", 28) # 指定位置
- print(s12)
- s12 = "我叫{name}, 今年{age}岁了, 我喜欢{singer}".format(name="周杰伦", singer="周润发", age=28) # 指定关键字
- print(s12)
4.查找
- s13 = "我叫sylar, 我喜欢python, java, c等编程语言."
- ret1 = s13.startswith("sylar") # 判断是否以sylar开头
- print(ret1)
- ret2 = s13.startswith("我叫sylar") # 判断是否以我叫sylar开头
- print(ret2)
- ret3 = s13.endswith("语言") # 是否以'语言'结尾
- print(ret3)
- ret4 = s13.endswith("语言.") # 是否以'语言.'结尾
- print(ret4)
- ret7 = s13.count("a") # 查找"a"出现的次数
- print(ret7)
- ret5 = s13.find("sylar") # 查找'sylar'出现的位置
- print(ret5)
- ret6 = s13.find("tory") # 查找'tory'的位置, 如果没有返回-1
- print(ret6)
- ret7 = s13.find("a", 8, 22) # 切片找
- print(ret7)
- ret8 = s13.index("sylar") # 求索引位置. 注意. 如果找不到索引. 程序会报错
- print(ret8)
5.条件判断
- # 条件判断
- s14 = "123.16"
- s15 = "abc"
- s16 = "_abc!@"
- # 是否由字母和数字组成
- print(s14.isalnum())
- print(s15.isalnum())
- print(s16.isalnum())
- # 是否由字母组成
- print(s14.isalpha())
- print(s15.isalpha())
- print(s16.isalpha())
- # 是否由数字组成, 不包括小数点
- print(s14.isdigit())
- print(s14.isdecimal())
- print(s14.isnumeric()) # 这个比较牛B. 中文都识别.比如一,二,壹,
- print(s15.isdigit())
- print(s16.isdigit())
- # 练习. 用算法判断某一个字符串是否是小数
- s17 = "-123.12"
- s17 = s17.replace("-", "") # 替换掉负号
- if s17.isdigit():
- print("是整数")
- else:
- if s17.count(".") == 1 and not s17.startswith(".") and not s17.endswith("."):
- print("是小数")
- else:
- print("不是小数")
6.计算机长度
- name = "我是你的眼, 我也是a"
- yuan = len(name) # 计算字符串的长度
- print(ret) #结果 9
注意len是Python的内置函数,所以访问方式也不一样.只需记住len和print一样即可
7.迭代
我们可以使用for循环来便利(获取)字符串中的每一个字符
语法:
for 变量 in 可迭代对象
- name= "大家好, 我是VUE, 前端的小朋友们. 你们好么?"
- index = 0
- while index < len(s19):
- print(s19[index]) # 利用索引切片来完成字符的查找
- index = index + 1
- # for循环, 把s19中的每一个字符拿出来赋值给前面的c
- name = "大家好, 我是VUE, 前端的小朋友们. 你们好么?"
- for c in name:
- print(c)
- #in有两种方法:
- 1.在for中,是把每一位元素获取到赋值给前面的变量
- 2.不在for中.判断xxxx是否出现在str中
- print('VUE' in name)
- #练习,计算机在字符串"I am sylar, I'm 14 years old, I have 2 dogs!"
- xiao = "I am sylar, I'm 14 years old, I have 2 dogs!"
- count = 0
- for c in xiao:
- if c.isdigit():
- count = count+1
- print(count)
字符串的转换:
- li = ["李嘉诚", "麻花藤", "郭海峰", "刘嘉玲"]
- s = "_".join(li)
- print(s) #结果 :李嘉诚_马化腾_郭海峰_刘嘉玲
- li = "黄花大闺女"
- s = "_".join(li)
- print(s) #结果:黄_花_大_贵_女
Python的基础类型(int,bool,str):的更多相关文章
- Python——字符转换(int , bool ,str)
while True: pass while 1: pass #效果相同,后者 效果更快 s = 1 y = bool (s) #结果为True,int只要不是0,就为真 s = 'abc' y = ...
- day3------基本数据类型int, bool, str,list,tuple,dict
基本数据类型(int, bool, str,list,tuple,dict) 一.python基本数据类型 1. int 整数. 主要用来进行数学运算 2. str 字符串, 可以保存少量数据并进 ...
- 基本数据类型int,bool,str
.基本数据类型(int,bool,str) 基本数据数据类型: int 整数 str 字符串. 一般不存放大量的数据 bool 布尔值. 用来判断. True, False list 列表.用来存放大 ...
- 三.int , bool , str
03.万恶之源-基本数据类型(int, bool, str) 本节主要内容: 1. python基本数据类型回顾 2. int----数字类型3. bool---布尔类型4. str--- 字符串类 ...
- 关于int,bool,str
今日主要内容 基本数据类型(int,bool,str) 1.基本数据数据类型: int 整数 str 字符串. 一般不存放大量的数据 bool 布尔值. 用来判断. True, False list ...
- python基础知识梳理----3基本数据类型,int,bool,str ,for 循环,迭代
一:python的基本类型 1.int -----整数,主要进行数学运算 2.str -----字符串,可以保存少量数据,并进行相关操作, 3. bool ---布尔类型,判断真假 4.list ...
- python基础(int,str,bool,list)
1数字int. 数字主要是用于计算用的,使用方法并不是很多,就记住一种就可以: bit_length() #bit_length() 当十进制用二进制表示时,最少使用的位数 v = 11 1 ...
- 第三天-基本数据类型 int bool str
# python基础数据类型 # 1. int 整数 # 2.str 字符串.不会用字符串保存大量的数据 # 3.bool 布尔值. True, False # 4.list 列表(重点) 存放大量的 ...
- day 03 int bool str (索引,切片) for 循环
基础数类型总览 10203 123 3340 int +- * / 等等 '今天吃了没?' str 存储少量的数据,+ *int 切片, 其他操作方法 True False bool 判断真假 [12 ...
随机推荐
- 【记录】使用Navicat将表设计导出数据库设计文档
INFORMATION_SCHEMA. Tables -- 表信息 INFORMATION_SCHEMA. COLUMNS -- 列信息 参考文章地址:https://blog.csdn.net/cx ...
- 机器学习-线性回归补充-R^
线性回归算法在选自变量会遇到两个问题:一是去掉多重共线性干扰,二是选择最优自变量组合. 线性回归步骤 1.选择自变量 注意点 去掉多重共线性干扰,选择最优自变量组合.这里需要理解决定系数:R^.它是理 ...
- 《TED演讲的秘密》:TED组织者总结的演讲技巧集锦。三星推荐。
对演讲感兴趣的可以看看.对TED内容感兴趣的也可以翻翻,书中有不少作者认为演讲技巧比较经典(一般来说内容上也有特色)的TED演讲的二维码.三星推荐.http://t.cn/RvFStu7
- javascript数组赋值操作的坑
描述:数组对象赋值,即arr1=[{},{},{}]这种数据结构的对象赋值,将arr1赋值给arr2:然后删除arr2里的元素 一.最常用的= arr2 = arr1; detect(val) { l ...
- cassandra集群
cassandra是分布式数据库属于nosql,用于处理大量商用服务器上的大量数据,提供高可用性,无单点故障. Cassandra在其节点之间具有对等分布式系统,并且数据分布在集群中的所有节点之间. ...
- django 添加分页功能的包
Django pagination based upon the core pagination module
- 【8.0.0_r4】AMS分析(十六)(ActivityManagerService.java上)
代码位于frameworks/base/services/core/java/com/android/server/am/,一共有七十个文件. Java源码位于package com.android. ...
- Android USB驱动源码分析(-)
Android USB驱动中,上层应用协议里最重要的一个文件是android/kernel/drivers/usb/gadget/android.c.这个文件实现USB的上层应用协议. 首先包含了一些 ...
- postman-Runner
postman Runner配置 preview查看参数
- jumpserver安装和使用
jumpserver安装 #centos6 centos7都可用yum -y install git python-pip mysql-devel gcc automake autoconf pyth ...