一、基本数据类型

基础数据类型,有7种类型,存在即合理。

  1.int 整数

 主要是做运算的。比如加减乘除,幂,取余 + - * / **  % ...

  2.bool 布尔值

 判断真假以及作为条件变量

  3.str 字符串

 存储少量的数据。‘太白’,‘password’...操作简单,便于传输。

  4.list 列表

 [1,2,‘alex’,{name:‘zhang’}]存放大量的数据,大量的数据放到列表中便于操作

  5.tuple 元组

 也叫只读列表。(1,2,‘alex’,{name:'zhang'})一些重要的数据或者不想被更改的数据,使用元组

  6.dict 字典

 {‘name_list’:“[zhang,lisi”]},存储关系型的数据,查询速度非常快,二分查找。

  7.set 集合

 交集,并集,差集

分别举例

  int整形

i = 4
#转化成二进制的最小位数
print(i.bit_length())
...
1 0000 0001
1 0000 0010
3 0000 0011
4 0000 0100
'''

数据类型转换:

  int --> str

n = str(1)

  int --> bool

n = bool(1)

  str --> bool

n = bool(' ')

  空字符串是False,其他都是True!!!

str字符串索引与切片

  字符串是有序的,有索引的,索引从0开始,默认取值是从左至右

s = 'python是最好的语言'
#取第一个字符
s1 = s[0]
#取索引值为2的元素
s2 = s[2]
#最后一个
s3 = s[-1]
print(s1)
print(s2)
print(s3)

语法:

[起始索引:截止索引:步长]

步长默认为1,表示从头开始取;切片,也就是取连续的多个值。切片原则,顾头不顾尾!!!

s = 'python是最好的语言'
s1 = s[0:2]
print(s1)

先看字符串的索引对应

p  y  t  h  o  n

↓  ↓  ↓  ↓   ↓  ↓

0 1  2  3  4  5

中文字符串也是同样的,一个中文字,即一个索引

s = 'python是最好的语言'
s1 = s[7:9]
print(s1)

全取

s = 'python是最好的语言'
s1 = s[:]
print(s1)

切片会产生新的变量,在内存中,原字符串和切片后的字符串,是2个变量;s4 = s[:]虽然结果是一样的,但它是2个变量,对字符串操作,都会产生新的变量,除了赋值以外。

取最后5个字符串

s = 'python是最好的语言'
s1 = s[-5:]
print(s1)

  步长

默认步长为1;隔一个取1个,步长为2;反向取值,也就是从后向前取,步长为-1

隔1个,取一个

s = 'python是最好的语言'
s1 = s[::2]
print(s1)

反向取5个

s = 'python是最好的语言'
s1 = s[-5:-1]
print(s1)

反向全取

s = 'python是最好的语言'
s1 = s[::-1]
print(s1)

字符串常用操作方法

capitalize() 首字母大写,其他字母小写

s = 'laoshi'
s1 = s.capitalize()
print(s1)

 upper() 全部大写

lower() 全部小写

s = 'laoshi'
s1 = s.upper()
s2 = s.lower()
print(s1,s2)

比如验证码判断功能

code = 'aeQu'
your_code = input('请输入验证码:')
if your_code.upper() == code.upper():
print('验证码验证成功')

代码优化一下

code = 'aeQu'.upper()
your_code = input('请输入验证码:').upper()
if your_code == code:
print('验证码验证成功')

 center() 居中

s = 'laoshi'
#总宽度为30,并且字符串居中,不足30,默认用空格填充
s1 = s.center(30)
#使用*填充
s2 = s.center(30,'*')
print(s1)
print(s2)

如果宽度小于字符串,按照原来的字符串显示

swapcase() 大小写反转

s = 'LaoShi'
s1 = s.swapcase()
print(s1)

 title() 每个单词的首字母大写(非字母隔开)

s = 'xiao wusir*nanhai'
s1 = s.title()
print(s1)

 startswith()  判断以什么为开头

endswith()  以什么结尾

startswith的start和end参数是切片,如果想取到最后,end参数,不需要指定

s = 'xiao wusir*nanhai21shui'
s1 = s.startswith('a')
s2 = s.endswith('i')
#切片,取索引访问1~4,再判断是否以i开头
s3 = s.startswith('i',1,4)
#切片,取索引范围5~结束,结束位置参数没给,默认一直取到尾
s4 = s.startswith('w',5)
print(s1)
print(s2)
print(s3)
print(s4)

 strip()  去除首尾的空格,换行符(\),tab键(4个空格用\t表示)

s = '\nlaoshi\t'
s1 = s.strip()
print(s1)

如果用户输入的内容不小心包含了空格,也可以验证通过

name = input('请输入用户名:').strip()
if name == 'xiao':
print('ok')

后续操作文件读取一行内容的时候,也会带有换行符,虽然你看不见,使用strip(),就可以去除了

✴lstrip() 去除左边的空格、换行符、tab键
✴rstrip() 去除右边的空格、换行符、tab键

strip()还可以去除指定的字符串

name = 'jingsan123'
s1 = name.isalnum()
s2 = name.isalpha()
s3 = name.isdigit()
print(s1,s2,s3)

 isdigit()比较常用,比如判断用户输入的,是否是数字。

name = '123a'
if name.isdigit():
name = int(name)
else:
print('您输入的含有非数字元素')

len() 查看数据的长度

name = 'zhangsan'
print(len(name))

二、for循环

先来使用while循环,打印每一个字符串

s = 'abcdef'
count = 0
while count < len(s):
print(s[count])
count += 1

使用for循环完成上面的功能

s = 'abcdef'
for i in s:
print(i)

for循环和while循环的区别在于
for 循环是有限循环
while 循环是无限循环

有些情况,在不需要终止条件的情况下,使用for循环
有终止条件的,使用while循环

for循环会自动停止

今日作业

1,有变量name = "aleX leNb" 完成如下操作:
1) 移除 name 变量对应的值两边的空格,并输出处理结果
2) 移除name变量左边的'al'并输出处理结果
3) 移除name变量右面的'Nb',并输出处理结果
4) 移除name变量开头的a'与最后的'b',并输出处理结果
5) 判断 name 变量是否以 "al" 开头,并输出结果
6) 判断name变量是否以"Nb"结尾,并输出结果
7) 将 name 变量对应的值中的 所有的"l" 替换为 "p",并输出结果
8) 将name变量对应的值中的第一个'l'替换成'p',并输出结果
9) 将 name 变量对应的值根据 所有的"l" 分割,并输出结果。
10) 将name变量对应的值根据第一个'l'分割,并输出结果。
11) 将 name 变量对应的值变大写,并输出结果
12) 将 name 变量对应的值变小写,并输出结果
13) 将name变量对应的值首字母'a'大写,并输出结果
14) 判断name变量对应的值字母'l'出现几次,并输出结果
15) 如果判断name变量对应的值前四位'l'出现几次,并输出结果
16) 从name变量对应的值中找到'N'对应的索引(如果找不到则报错),并输出结果
17) 从name变量对应的值中找到'N'对应的索引(如果找不到则返回-1)输出结果
18) 从name变量对应的值中找到'X le'对应的索引,并输出结果
19) 请输出 name 变量对应的值的第 2 个字符?
20) 请输出 name 变量对应的值的前 3 个字符?
21) 请输出 name 变量对应的值的后 2 个字符?
22) 请输出 name 变量对应的值中 "e" 所在索引位置?
23)获取子序列,去掉最后一个字符。如: oldboy 则获取 oldbo。 2,有字符串s = '123a4b5c'
1)通过对li列表的切片形成新的字符串s1,s1 = '123'
2)通过对li列表的切片形成新的字符串s2,s2 = 'a4b'
3)通过对li列表的切片形成新的字符串s3,s3 = '1345'
4)通过对li列表的切片形成字符串s4,s4 = '2ab'
5)通过对li列表的切片形成字符串s5,s5 = 'c'
6)通过对li列表的切片形成字符串s6,s6 = 'ba2' 3,使用while和for循环分别打印字符串s='asdfer'中每个元素。
4,实现一个整数加法计算器(两个数相加):
如:content = input('请输入内容:') # 如用户输入:5+9或5+ 9或5 + 9,然后进行分割再进行计算。
5,计算用户输入的内容中有几个整数(以个位数为单位)。
如:content = input('请输入内容:') # 如fhdal234slfh98769fjdla

Python全栈开发,Day3的更多相关文章

  1. Python全栈开发day3

    1.Pycharm使用介绍 1.1 新建py文件自动添加python和编码 1.2 更改pycharm默认字体和风格 点击左上角“file”-->“Settings”(或者用“Ctrl+Alt+ ...

  2. python全栈开发-Day3 字符串

    python全栈开发-Day3 字符串 一.按照以下几个点展开字符串的学习  #一:基本使用 1. 用途 #首先字符串主要作用途径:名字,性别,国籍,地址等描述信息2.定义方式 在单引号\双引号\三引 ...

  3. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  4. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  5. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  6. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  7. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

  8. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  9. Python全栈开发【基础一】

    Python全栈开发[第一篇] 本节内容: Python 的种类 Python 的环境 Python 入门(解释器.编码.变量.input输入.if流程控制与缩进.while循环) if流程控制与wh ...

  10. python 全栈开发之路 day1

    python 全栈开发之路 day1   本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...

随机推荐

  1. JMeterContext----上下文

    http://jmeter.apache.org/api/org/apache/jmeter/threads/JMeterContext.html org.apache.jmeter.threads ...

  2. 升级到mysql5.7无法启动问题解决

    漏洞扫描,老项目升级到5.7位成功,启动发现报错:unknown option log_error 线备份my.cnf配置文件, 猜测应该是写法有问题,先把log_error  改成log #log_ ...

  3. 第一章:Java语言概述与环境开发

    1.计算机高级语言按程序的执行方式可以分为编译型和解释型两种: 2.JAVA程序的执行过程必须经过先编译后解释两个步骤: 3.JAVA语言里负责执行字节码文件的是JAVA虚拟机 (Java Virtu ...

  4. Tesseract5.0训练字库,提高OCR特殊场景识别率,合并字库(二)

    一.准备工作 需要的文件 tif文件和box文件. 如果你打标打好了,但是是分批次打标的,那么可以合并字库,我们最初只需要 tif 和 box 文件,如下: 二.生成对应的 .tr 训练文件 根据不同 ...

  5. Maven构建SpringMVC+Mybatis项目

    1.创建Maven项目时,起始是没有src/main/java.src/test/java.src/test/resources,需要修改一些配置之后,自动就会创建出来: 2.开始引入Spring+M ...

  6. Java 中的 T,E,K,V, 别傻傻分不清楚!

    作者:glmapper https://juejin.im/post/5d5789d26fb9a06ad0056bd9 前言 Java 泛型(generics)是 JDK 5 中引入的一个新特性, 泛 ...

  7. QT 5.12安装

    QT 5.12为最新的LTS版本,将通过该版本开始QT的学习 1.软件下载 QT5.12下载地址:http://download.qt.io/archive/qt/5.12/ 当前最新版本为5.12. ...

  8. Windows注册表内容详解

    Windows注册表内容详解 http://blog.sina.com.cn/s/blog_4d41e2690100q33v.html (2011-04-05 10:46:17)   第一课  注册表 ...

  9. 提升JAVA代码的好“味道”

    让代码性能更高 需要 Map 的主键和取值时,应该迭代 entrySet() 当循环中只需要 Map 的主键时,迭代 keySet() 是正确的.但是,当需要主键和取值时,迭代 entrySet() ...

  10. 【记录】form-data与x-www-form-urlencoded的区别

    1)application/x-www-form-urlencoded 这应该是最常见的 POST 提交数据的方式了.浏览器的原生 <form> 表单,如果不设置 enctype 属性,那 ...