3.Python自我修炼(升仙中....整数,布尔值,字符串,for循环)
python学习(整数,布尔值,字符串,for循环)
1.整数
在python3中所有的整数都是int类型. 但在python2中如果数据量比较大. 会使用long类型.但是在python3中不存在long类型.
整数可进行的操作 :
bit_length(). 计算整数在内存中占用的二进制码的长度.
2.再谈布尔值
取值只有True,False(bool值没有操作)
转换问题:
- str => int int(str)
- int => str str(int)
- int => bool bool(int). 0是False 非0是True
- bool=>int int(bool) True是1, False是0
- str => bool bool(str) 空字符串是False,不空是True
- bool => str str(bool) 把bool值转换成相应的"值"
3.字符串
字符串用于存储数据,但存储数据量比较少,在python中用 ' (单引号) "(双引号) '''(单引号三三引) """(双引号三引)引起来的内容被称为字符串.
字符串与索引的关系及其操作如下 :
索引(下标)
索引就是下标,下标从0开始,取值时索引所选长度不可以超过其本身.
s1 = "python学习"
print(s1[0]) # 获取第0个索引所对应的的元素.
print(s1[1]) # 同上
print(s1[2]) # 同上
print(s1[3]) # 同上
print(s1[4]) # 同上
print(s1[5]) # 同上
print(s1[6]) # 同上
print(s1[7]) # 同上
print(s1[8]) # 同上
print(s1[9]) # 没有9,越界了会报错,索引长度不可以超过本身
print(s1[-1]) # -1表示倒数第一个
print(s1[-2]) # 倒数第二个
切片
语法 : str[start:end]
规则 : 顾头不顾腚,从start开始截取,截取到end位置,但不包括end,切片长度可以超出范围.
用法 : 我们可以使用下标来截取部分字符串的内容
s2 = "python好学习"
print(s2[0:3]) # 从0获取到3,不包含3,结果:pyt
print(s2[6:8]) # 结果:好学
print(s2[6:9]) # 最答是8,但根据顾头不顾腚,想要取到8必须给9
print(s2[6:10]) # 如果右边已经过了最答值,相当于获取到最后,切片长度可以超出范围,索引长度不可以.
print(s2[4:]) # 如果想获取到最后,那么:后可以不放值.
print(s2[-1:-5]) # 从-1获取到-5这样是获取不到任何结果的,从-1向右数,取值方向向右,数不到-5.
print(s2[-5:-1]) # 取到学习这个数据了,但是,顾头不顾尾,取不到最后一个.
print(s2[-5:]) # 什么都不写就是取值到最后
print(s2[:-1]) # 这个是取到倒数第一个值,但不包含倒数第一的这个值
print(s2[:]) # 取全部
步长
切片语法 : str[start : end : step]
- start : 起始位置
- end : 结束位置
- step : 步长
步长用法 : 如果是整数,则从左往右取,如果是负数,则从右往左取,step默认是1取值方向从左往右.
s2 = "python好学习"
print(s2[1:5:2]) # 从索引为1的位置开始取,取到索引为4的位置,每2个取1个,结果:yh
print(s2[:5:2]) # 从索引为0的位置开始到索引为4的位置,每两个取一个
print(s2[4::2]) # 从索引为4的位置开始取到最后,每两个取一个
print(s2[-5::2]) # 从索引为-5的位置取到最后.每两个取一个
print(s2[-1:-5]) # 从索引为-1的位置取到索引为-4的位置,但是什么都没有,因为取的方向是从左往右
print(s2[-1:-5:-1]) # 从索引为-1的位置取到索引为-4的位置,步长是-1,取的方向这时就从右往左.
print(s2[-5::-3]) # 从索引为-5的位置开始取到最开始,每三个取一个,结果:oy
字符串常用方法
注意 : 切记,字符串是不可变的对象,所以任何操作对原字符串是不会有任何影响.
大小写互相转换,常应用于校验用户输入的验证码是否合法
# 首字母大写
s1.capitalize()
print(s1) # 输出发现并没有任何的变化,因为这里的字符串本身是不会发生改变的,需要我们重新赋值后用.
ret1 = s1.capitalize()
print(ret1)
---------------------------------
# 全部转换成小写
ret = s1.lower()
print(ret)
---------------------------------
# 全部转换成大写
ret = s1.upper()
print(ret)
---------------------------------
# 大小写互相转换
ret = s1.swapcase()
print(ret)
---------------------------------
ret = s1.casefold() # 用于转换成小写,此方法不常用,和lower的区别:lower()对某些字符支持不够好.
casefold()对所有字母都有效,比如东欧的一些字母
print(ret) s2 = "БBß" # 俄美德
print(s2)
print(s2.lower()) # 打印结果比对可以看到lower无法对德语转化
print(s2.casefold())
---------------------------------
# 每个被特殊字符隔开的字母首字母大写
s = "eggon,taibai*yinwang"
ret = s.title()
print(ret)# 打印结果 Eggon,Taibai*Yinwang
s = "你好chen你好shuo我是" # 你好Chen你好Shuo我是 中问也算是特殊字符
print(s4.title())
字符串的切割
# 居中
s = "周杰伦"
ret = s.center(10, "*") # 拉长成10,把原字符串放中间,其余位置补*
print(ret)
---------------------------------
# 更改tab的长度
s = "alir\teon"
print(s)
print(s.expandtabs()) # 可以改变\t的长度, 默认长度更改为8
---------------------------------
# 去空格,常用于当用户登录时,忽略用户输入的空格
s = " chen shuo nihao "
ret = s.strip() # 去掉左右两端的空格
print(ret)
ret = s.lstrip() # 去掉左边空格
print(ret)
ret = s.rstrip() # 去掉右边空格
print(ret)
---------------------------------
# 字符串替换
s = "chen_shuo_nihao"
ret = s.replace('chen', 'hehe') # 把chen替换成hehe
print(s) # 注意,字符串是不可变对象. 所有操作用返回值
print(ret) # hehe_shuo_nihao
ret = s.replace('n', 'yy', 2) # 把c替换成yy, 替换2个
print(ret) # 打印结果 cheyy_shuo_yyihao
---------------------------------
# 字符串切割
s = "chen,shuo,ni,hao"
lst = s.split(",") # 字符串切割,根据","进行切割
print(lst) # 打印结果是列表形式 ["chen","shuo","ni","hao"]
#如果切割符在左右两端,那么一定会出现空字符串,深坑请留意.
字符串的查找
s = "我叫sylar,我喜欢python,java,c等编程语言."
ret1 = s.startswith("sylar") # 判断是否以sylar开头
print(ret1)
ret2 = s.startswith("我叫sylar") # 判断是否以我叫sylar开头
print(ret2)
---------------------------------
ret3 = s.endswith("语言") # 是否以'语言'结尾
print(ret3)
ret4 = s.endswith("语言.") # 是否以'语言.'结尾
print(ret4)
---------------------------------
ret7 = s.count("a") # 查找"a"出现的次数
print(ret7)
---------------------------------
ret5 = s.find("sylar") # 查找'sylar'出现的位置
print(ret5)
ret6 = s.find("tory") # 查找'tory'的位置,如果没有返回-1
print(ret6)
ret7 = s.find("a", 8, 22) # 切片找
print(ret7)
---------------------------------
ret8 = s.index("sylar") # 求索引位置,注意,如果找不到索引,程序会报错
print(ret8)
is 系列
ret=1234
ret.isdecimal # 判断是不是十进制
ret.isalnum # 判断是不是中文,字母,数字
ret.isalpha # 判断是不是中文,字母
ret.isdigit # 判断是否由纯数字组成
计算字符串的长度
s = "你好我是***"
ret = len(s) # 计算字符串的长度度
print(ret) # 打印结果为7
# len()是python的内置函数
4.for循环
for循环用法 : 我们可以使用for循环来便利(获取)字符串中的每一个字符.
for语法:
for 变量 in 可迭代对象:
pass
可迭代对象: 可以一个一个往外取值的对象in的用法:
在for中. 是把每一个元素获取到赋值给前面的变量.
不在for中. 判断xxx是否出现在str中.
# for循环, 把s中的每一个字符拿出来赋值给前面的c
s="大家好,我是python学习者"
for c in s:
print(c) # 注意缩进字符
print(c) # 此时打印结果为for循环最后一次c的取值 # in在python中的用法
print('pyt' in s) # 此时打印出的结果是Ture
5.range范围
语法 : range(start,end,step)
- start : 起始位置
- end : 结束位置
- step : 步长
注意 : 顾头不顾尾,当range(10)为此形式时,起始位置默认从0开始到9结束,打印10次
3.Python自我修炼(升仙中....整数,布尔值,字符串,for循环)的更多相关文章
- 整数 布尔值 字符串 for循环
整型和布尔值的转换 整型---数字(int) 用于比较和运算 32位范围 -2** 31到2 **32-1 64位范围-2** 63到2** 63-1 十进制转二进制计算方法: 15的二进制为 15% ...
- 整型 布尔值 字符串 for循环
1.整型 2.布尔值 3.字符串 4.for循环 1.整型:.python中有长整型, Python3中只有整型 2.布尔值: bool:Ture 真 False 假 数字和布尔值可进行转 ...
- python基础语法_python中的布尔类型详解
转自:http://www.cnblogs.com/521yywzyzhc/p/6264885.html 我们已经了解了Python支持布尔类型的数据,布尔类型只有True和False两种值,但是 ...
- 4、python中的布尔值和None
一.布尔值 1.布尔值只有两个:True.Flase,表示python语句的真与假: 2.在python早期的版本,布尔值用1和0表示. 二.None 1.None表示虚无,什么也没有: 2.千万不要 ...
- jQuery.extend()中的布尔值的作用
jQuery.extend()中,第一个参数可以添加一个布尔值,表示是否深层拷贝,默认是false.但如果设置为true,则表示深层拷贝. 下面来看看什么是深层拷贝: <script type= ...
- python 整型,布尔值,字符串相关
1.整型(int) 就是所有整数, 2.布尔值(bool) True False 0,"",[],{},(),none为False 3.字符串(str) 字符: 是单一文字符号 字 ...
- python七类之整型布尔值
整型与布尔值 一.关键字:整型 --->int 布尔值----->bool : True 真 False 假 1.整形和布尔值都是不可变得不可迭代的数据类型 2.整型: 主 ...
- 整型,布尔值,字符串详解,for语句
整型 -- 数字 用于比较和计算 + - * / // python 2 int --- long (长整型) /获取的是整数 Python3 int---整型 / 获取的浮点数 二进制 --- 就是 ...
- [日常] Go语言圣经--复数,布尔值,字符串习题
go语言圣经-复数 1.我们把形如a+bi(a,b均为实数)的数称为复数,其中a称为实部,b称为虚部,i称为虚数单位.两种精度的复数类型:complex64和complex128,分别对应float3 ...
随机推荐
- html5 file 上传图片
说明:开发环境 vs2012 mvc4项目,后台语言csharp 1.前端代码 <html xmlns="http://www.w3.org/1999/xhtml"> ...
- HDOJ 4689 Derangement DP
DP具体解释见: http://blog.csdn.net/liguan1/article/details/10468139 Derangement Time Limit: 7000/7000 MS ...
- myeclipse10.0如何集成Git
现需要给myeclipse10.0集成git工具,经过搜索资料,现整理如下方法: myeclipse10.0对应的Git版本应该为:egit版本为2.3.1 下载地址:http://wiki.ecli ...
- 开发指南专题十一:JEECG微云高速开发平台--基础用户权限
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/zhangdaiscott/article/details/26580037 开发指南专题 ...
- vim实现代码缩进和可视区域的字符串替换
今天2014年9月12号,实现了vim下的代码自动缩进和替换可视区域的字符串,之前一直在用vim这个强大的编辑器,它的强大只有用了的人才知道,现在把这两个很强大的功能展示出来,有个这两个功能,即使你写 ...
- spring和springmvc中,Configuration注解Bean重复加载
问题:bean重复加载1.如下代码所示,开启Configuration注解,实现Bean代码注入,发现bean重复加载 @Configuration public class EhCacheConfi ...
- 使用grunt中遇到的问题
1.使用jshint进行代码检查时,grunt命令后报错: 因为出现了乱码,我猜测是因为编码原因导致的.遂在webstorm的setting中修改了编码为utf-8,问题解决.
- 如何在Flask的构架中传递logger给子模块
Logger的传递 作为一个新手,如何将主函数的logger传入子模块是一件棘手的事情.某些情况下可以直接将logger作为参数传入子模块的构造函数中,但倘若子模块与主模块存在相互依赖的关系则容易出现 ...
- map插入与查找
用map构建映射关系可以用来离散化,这里记录一下用法: 插入:将要插入的两个值组成pair,用insert插入map中: 查找:定义iterator,赋成find返回的迭代器,如果没有找到则=mp.e ...
- AndroidStudio检测不到genymotion虚拟设备
重启adb 单击 Reset adb