数字类型

1、整型:整数

  num = 1000000000000

  type(num)  --->int

2、浮点型:小数

  num = 123.2341

  type(num)  --->float

3、布尔值:True  Flase(可以转换成0和1进行任何int可以进行运算)

  布尔值实质就是int 0 和 1 的转换

  print(True + True)  --->2

4、复数(了了解)

  num = complex(3,4)  # num = 3 + 4j

5、数据类型的转换(整型、浮点型、布尔值随意转换)

  n1 = 10 ; n2 = 3.74 ; n3 = True

  print(int(n1),int(n2),int(n3))    -->10  3  1

  print(float(n1),float(n2),float(n3))   -->10.0    3.74     1.0

  print(bool(n1),bool(n2),bool(n3))      -->True  True  True

  注:浮点型转换成整型是取整,后面小数舍弃

字符串类型(所有数据类型都可以转换成字符串类型)

定义:被多种引号包裹的被称为字符串(' ' | " " | ''' ''' | """ """)

输出需求不同,通过不同的引号来完成

字符串的常规操作

1、通过索引取值(index)#从0开始

  n = '123abc奥尔'

  print(n[3],type(n[3]))  --->  a   str

#注:index从0开始,如果索引超过字符的个数,就会报错

2、切片(取子字符串,[ : : ])

  n = '123abc奥尔'

    1) print(n[::])  取出整个字符串     '123abc奥尔'

    2) print(n[2::])  取出从2开始到结尾的字符串  '3abc奥尔'

    3)print(n[2:5:])  取出从2开始到5(不包括5)结尾的字符串  '3ab'

    4)print([2:5:2])  取出从2开始到5(不包括5)结尾,步长为2的字符串  '3b'

    5)print(n[::-1])   步长为-1,倒着取值    '尔奥cba321'

3、长度(len)

  n = '123abc奥尔'

  print(len(n))  --->8

4、成员运算(in     not in)

  n = '123abc奥尔'

  print('123' in n)    -->True

  print('13a' in n)    -->False

#注:必须是连续的在里面出现,才是True,不能跳

5、for循环(遍历)

  n = '123abc奥尔'

  for i in n:

    print(i,end='')  -->'1' '2' '3' 'a' 'b' 'c' '奥' '尔'

6、字符串的拼接

  1)两个字符串类型拼接直接用字符串的基础运算

    str +str =str

  2)不同类型拼接

    a)都先转换成字符串类型再进行拼接

      str(int) + str +str(bool) = str

    b)格式化拼接

      str = '%s%s%s'%(str,int,bool)

        a = 10
        b = "20"
        c = True
        res = "%s%s%s" % (a, b, c) 
        print(res)      ==># res = "1020True"

重要方法

1、去留白(去除两边的空白) #strip()

  n = '******owen******'

  print(n.strip('*'))  #取出字符串两边的*,如果strip()括号里不填默认去除两边的空格

             #lstrip()只去除左边的空格,rstrip()只去除右边的空格

#注:strip()只会去除两边的空格或者字符,并不会去除中间的。

2、查找字符的索引  #index()

  n = '123abc奥尔12312'

  print(n.index(a,start,end))  #查找a在n中的索引 ,可以设置查找的区间[start,end)

#注:如果n中存在多个a,只会查找到区间中第一个a的索引

#  找不到就会报错,(下文提到的find也是查找字符的索引,找不到返回-1)

3、计数(某个字符出现的个数)  #count()

  n = '123abc奥尔12312'

  print(n.count('123'))  -->2

  print(n.count('12'))    -->3  

#找不到就返回0

4、format格式化输出

  1)'name:{},age:{},height:{}'.format('owen',18,160)  #按顺序添加,后面的值必须和前面的{}一一对应

                           #后面值的个数比前面少就会报错,多的话不会报错但也取不到(没意义)

  2)'name:{0},age:{1},height:{1}'.format('owen',18)  #按索引添加,后面的值可以循环使用

  3)'name:{na},age:{ag},height:{he}'.format(na = 'owen',ag = 18,he = 160)   #按key添加,forrmat后面元素不用理顺序

5、判断字符是否是数字(isdigit)

  n = '123'

  print(n.isdigit())  -->True

#注:只能判断自然数(正整数和0),负数和小数返回False

6、大小写转换

  1)全部转换成大写  #upper()

    name = 'oWeN'

    print(name.upper())  -->OWEN

  2)全部转换成小写  #lower()

    name = 'oWeN'

    print(name.lower())  -->owen

  3)首字母大写(其他转换成小写)  #capitalize()

    name = 'oWeN'

    print(name.capitalize())  -->Owen

  4)单词首字母大写(其他转换成小写)  #title()

    name = 'oWeN keVin'

    print(name.title())    -->Owen Kevin

7、是否以什么开头什么结尾  #startswith()      endswith()

  name = 'oWeN keVin'

  print(name.startswith('ow'))  -->False

  print(name.endswith('in'))     -->True

8、替换  #replace(old,new,count)

  name = 'oWeN keVin'

  print(name.replace('e','E'))  'oWEN kEVin'    #把所有的e全部改成'E'

  print(name.replace('e','E',1))  'oWEN keVin'   #只改一个

了解

1. find | rfind:查找子字符串索引,无结果返回-1
2. lstrip:去左留白
3. rstrip:去右留白
4. center | ljust | rjust | zfill:按位填充
语法:center(所占位数, '填充符号')
5. expandtabs:规定\t所占空格数
6. captialize | title | swapcase:首字母大写 | 单词首字母大写 | 大小写反转
7. isdigit | isdecimal | isnumeric:数字判断
8. isalnum | isalpha:是否由字母数字组成 | 由字母组成
9. isidentifier:是否是合法标识符
10. islower | isupper:是否全小 | 大写
11. isspace:是否是空白字符
12. istitle:是否为单词首字母大写格式

列表类型

定义:被[]包起来的为列表,中括号里为任意类型的值

ls = [1,2]  #本质是ls = list([1,2])

列表的常规操作

1、通过索引取值

2、切片

3、成员运算

4、for循环(遍历)

5、长度

6、列表的拼接

##参考上面字符串常规操作方法

对于for循环有一个案例:

#ls = [1,2,3,'4',5,6]  现在的需求是只打印列表ls里的数字

for i in ls:

  if isinstance(i,int):

    print(i)

##涉及到isinstance的使用  isinstance(变量,(数据类型))

##括号里的数据类型可以是一个也可以是多个,作用就是判断该变量的类型在不在括号中

##在返回True   不在返回False

增删改查

ls = [1,2,3,'4',5,6]

print(ls[2])   --> 3

增 append()与insert()

append()

  在列表的末尾添加

insert(index,变量)

  按索引添加元素,添加在index之前

删 remove()  pop()

remove(元素)

  删除指定元素,没有返回值 从前往后开始删除,只能删除第一次出现的元素

pop(index)

  按索引删,如果不输入默认从末尾删,有返回值,如果索引超出范围就会报错

ls = [1,2,3,'4',5,6]

ls[2]='a'

print(ls)    -->[1,2,a,'4',5,6]

了解

1、排序  #sort()   只能排序同种类型,字符串也能排序

ls = [3,1,2]

print(ls.sort())  -->[1,2,3]  #正向排序

print(ls.sort(reverse = True))  #正向排序的基础再反转(默认reverse = False(不反转))

2、反转  #reverse

ls = [3,1,2]

print(ls.reverse())  [2,1,3]

3、计算出现的次数  #count()

参考字符串

了了解

1、整体添加  #extend()

2、查找元素的索引  #index(元素)

  可以规定区间,只返回元素第一次出现的索引

  不写默认全部区间查找

可变与不可变类型

1. 可变类型:值改变,但是id不变,证明就是在改变原值,是可变类型

2. 不可变类型:值改变,但是id也跟着变,证明是产生了新的值,是不可变类型

##可变不可变主要是针对id不变的情况下,值可以变就是可变类型,反之亦然

  

python day05的更多相关文章

  1. My way to Python - Day05 - 面向对象-思维导图

    My way to Python - Day05 - 面向对象   思维导图

  2. python day05笔记总结

    2019.4.2 S21 day05笔记总结 一.昨日内容回顾与补充 1.extend(列表独有功能) 循环添加到一个列表中 a.有列表users = ['张三',‘李四]   people = [' ...

  3. My way to Python - Day05 - 面向对象

    思维导图

  4. python day05 作业答案

    1. b.不可以 c.tu=("alex",[11,22,{"k1":"v1","k2":["age" ...

  5. python day05字典

    一.字典 1.字典的结构: a={key:value,key2:value},key是不可变的,value是可变的. 例子:dic = {123: 456, True: 999, "id&q ...

  6. python day05作业

  7. 铁乐学Python_day05-字典dict

    1.[字典dict] Python内置了字典:dict的支持,dict全称dictionary, 在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度. 字典和列表直观上 ...

  8. Python基础(协程函数、内置函数、递归、模块和包)-day05

    写在前面 上课第五天,打卡: 凭着爱,再回首: 一.协程函数(生成器:yield的表达式形式) 1.yield 的语句形式: yield 1 - 这种方式在 Python基础(函数部分)-day04  ...

  9. python开发学习-day05(正则深入、冒泡排序算法、自定义模块、常用标准模块)

    s12-20160130-day05 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...

随机推荐

  1. Kafka Ecosystem(Kafka生态)

    http://kafka.apache.org/documentation/#ecosystem https://cwiki.apache.org/confluence/display/KAFKA/E ...

  2. GitHub开源:SQLite 增强组件 Sheng.SQLite.Plus

    Github:https://github.com/iccb1013/Sheng.SQLite.Plus Sheng.SQLite.Plus 是一个对直接使用 ADO.NET 方式操作 SQLite ...

  3. [Swift]LeetCode1034.边框着色 | Coloring A Border

    Given a 2-dimensional grid of integers, each value in the grid represents the color of the grid squa ...

  4. Entity Framework 异常: 'OFFSET' 附近有语法错误。\r\n在 FETCH 语句中选项 NEXT 的用法无效。

    在使用 EF 的时候,突然发现更新后在服务器中运行出错,异常信息主要包含以下信息: 'OFFSET' 附近有语法错误.\r\n在 FETCH 语句中选项 NEXT 的用法无效.\r\n关键字 'AS' ...

  5. 【Android Studio安装部署系列】一、JDK开发环境搭建

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 Android Studio安装后自带jre,这个自带jre的版本号肯定比最新的版本号要小. 但是如果项目中没有用到新版本jdk的特 ...

  6. Scrum Mastery:产品开发中如何优化产品价值?

    您是否在开发对组织来说有价值的产品?如何判断产品是否有价值? 如果没有经常提出这两个问题,那么您可能忽略了产品价值方面的问题. 产品是目前工作所要达成的目的,是组建团队的原因.产品也是你选择Scrum ...

  7. 4.4管道和中间件介绍「深入浅出ASP.NET Core系列」

    希望给你3-5分钟的碎片化学习,可能是坐地铁.等公交,积少成多,水滴石穿,谢谢关注. 管道流 我们知道一个管道可以有一个或多个中间件,而中间件的职责是根据HttpContext处理HTTP请求,然后往 ...

  8. springcloud情操陶冶-springcloud config server(一)

    承接前文springcloud情操陶冶-springcloud context(二),本文将在前文基础上浅析下ConfigServer的工作原理 前话 根据前文得知,bootstrapContext引 ...

  9. Shell编程(week4_day4)--技术流ken

    本节内容 1. shell函数 2. shell正则表达式 shell函数 shell中允许将一组命令集合或语句形成一段可用代码,这些代码块称为shell函数.给这段代码起个名字称为函数名,后续可以直 ...

  10. 🧬 C# 神经网络计算库和问题求解

    Andrew Kirillov 著 Conmajia 译 2019 年 1 月 12 日 原文发表于 CodeProject(2006 年 11 月 19 日),已获作者本人授权. 本文介绍了一个用于 ...