字符串常用操作
# ======================================基本使用======================================
# 1、用途:记录描述性质的状态 # 2、定义方式:在单引号、双引号、三引号内包含的一串字符
# msg = "[1,2,3]" # msg=str("[1,2,3]") # 数据类型转换:str可以把任意类型转换成字符串类型
# str([]) # 3、常用操作+内置的方法
# 优先掌握的操作:
# 1、按索引取值(正向取+反向取) :只能取
# msg='hello你好'
# print(msg[0]) # 取出的由单一字符组成的str
# print(msg[5])
# print(msg[-1]) # l=[1111,222]
# l[0]=3333
# print(l) # msg="hello"
# msg[0]="H" # 2、切片(顾头不顾尾,步长)
msg = 'hello你好'
# print(msg[1:6]) # ello你
# print(msg) #字符串不会变 # print(msg[1:6:1]) # 默认步长,1 2 3 4 5
# print(msg[1:6:2]) # 默认步长,1 3 5 # print(msg[:6:2]) # 省略起始位置,默认起始位置为0
# print(msg[::2]) # 省略结束位置,默认一直到末尾全部都取到
# print(msg[::]) # 省略步长,默认步长为1
# print(msg[:]) # 省略步长,默认步长为1 # 了解:
# msg='hello你好'
# print(msg[0:5:1])
# print(msg[0:5:-1])
# 方向需要保持一致才行
# print(msg[-1:-5:-1]) # -1 -2 -3 -4
# 好 你 o l # msg = 'hello你好'
# print(msg[::-1]) # -1 # 3、长度len
# msg = 'hello \n你好'
# print(len(msg)) # 统计的是字符的个数 # 4、成员运算in和not in
# msg = 'hello 你好'
# print("你好" in msg)
# print("你好" not in msg) # 推荐使用
# print(not "你好" in msg) # 不推荐使用 # 5、移除空白strip
# msg=" hello "
# res=msg.strip()
# print(res) # msg=" \t \n hello \t"
# res=msg.strip() # 默认去掉的是字符串左右两端的空白字符串
# print(res) # msg=" \t \n he llo \t"
# res=msg.strip() # 默认去掉的是字符串左右两端的空白字符串
# print(res) # msg="*()-=hello()*&#@!"
# res=msg.strip("()*=-!&#@")
# print(res) # 得到的是新字符串,没有改变原来的
# print(msg) # user = input('用户名>>>: ').strip() # user="egon "
# password = input('密码>>>: ').strip()
# if user == "egon" and password == "123":
# print('账号密码正确')
# else:
# print("账号或密码输入错误") # 6、切分split
# msg="a:b:c:d"
# res=msg.split(':')
# print(res)
#
# msg="hello 你 好"
# print(msg.split(' ')) # msg="a:b:c:d"
# res=msg.split(':') # 把列表拼成一个str,列表中的元素必须全部为str类型
# print(res)
# print(":".join(res)) # 'a'+":"+'b'+":"+'c'+':'+"d"
# print("-".join(res))
# print("=".join(res))
#
# # 7、循环
# for x in "hello 你好":
# print(x) # 需要掌握的操作
# 1、strip,lstrip,rstrip
# msg="*****hello*****"
# print(msg.strip('*'))
# print(msg.lstrip('*'))
# print(msg.rstrip('*'))
# 2、lower,upper
# msg="aABc你1"
# print(msg.lower())
# print(msg.upper()) # 3、startswith,endswith
msg = "dsb lxx is sb"
# print(msg.startswith("ds"))
# print(msg.endswith("sb")) # 4、format的三种玩法
# print("my name is %s %s" % ("egon",18)) # print("my name is {} {}".format("egon",18))
# print("my name is {x} {y}".format(y=18,x="egon"))
# print("my {1}name is {0} {0}{1}{1}".format("egon",18)) # x='egon'
# y=18
# print(f"=====>{x}===>{y}") # 5、split,rsplit
# print("egon:18:male:10".split(':',2))
# print("egon:18:male:10".split(':',1))
# print("egon:18:male:10".rsplit(':',1)) # 6、join # 7、replace
# msg="*()-=he llo()*&#@!"
# res=msg.strip("()*=-!&#@").replace(' ','')
# print(res) # print('my name is sb sb sb'.replace('sb','SB',1)) # 8、isdigit
# age="18**** "
# print(age.isdigit()) #
# age = input('>>>: ') # age = "***18_++_ "
# if age.isdigit():
# age = int(age)
# if age > 18:
# print('猜大了')
# elif age < 18:
# print("猜小了")
# else:
# print('猜对了')
# else:
# print("必须输入数字,小垃圾") # 了解操作
#1、find,rfind,index,rindex,count
# print("=abcdefab".find("ab")) # 查找一个子字符串在大字符串中出现的起始位置
# print("=adcabdefab".find("ab",0,6)) # 查找一个子字符串在大字符串中出现的起始位置
# print("=adcabdefab".rfind("ab")) # 查找一个子字符串在大字符串中出现的起始位置
# print("====".index("ab")) # 找不到则报错,而find则会返回-1 #2、center,ljust,rjust,zfill
# print("egon".center(50,'*'))
# print("egon".ljust(50,'*'))
# print("egon".rjust(50,'*'))
# print("egon".zfill(50)) #3、expandtabs #4、captalize,swapcase,title
# print("my name is egon".capitalize())
# print("AbCd".swapcase())
# print("my name is egon".title()) #5、is数字系列
#在python3中
# num1=b'4' #bytes
# num2=u'4' #unicode,python3中无需加u就是unicode
# num3='四' #中文数字
# num4='Ⅳ' #罗马数字 # isdigit():用于b和u格式,即num1和num2
# isdecimal():用于u格式,即num2
# isnumberic():用于u,中文数字、罗马数字,即num2、num3、num4 #isdigt:bytes,unicode
# print(num1.isdigit()) #True
# print(num2.isdigit()) #True
# print(num3.isdigit()) #False
# print(num4.isdigit()) #False #isdecimal:uncicode
#bytes类型无isdecimal方法
# print(num2.isdecimal()) #True
# print(num3.isdecimal()) #False
# print(num4.isdecimal()) #False #isnumberic:unicode,中文数字,罗马数字
#bytes类型无isnumberic方法
# print(num2.isnumeric()) #True
# print(num3.isnumeric()) #True
# print(num4.isnumeric()) #True #三者不能判断浮点数
# num5='4.3'
# print(num5.isdigit())
# print(num5.isdecimal())
# print(num5.isnumeric()) #6、is其他
# name='egon123'
# print(name.isalnum()) #字符串由字母或数字组成
# print(name.isalpha()) #字符串只由字母组成 # name="====>inputasd" # "input" in name
# print(name.isidentifier()) # name="egon"
# print(name.islower())
# print(name.isupper()) # name=" "
# print(name.isspace()) # name="My Name Is"
# print(name.istitle()) # ======================================该类型总结====================================
# 存一个值or存多个值
# 存一值 # 有序or无序
# 有序 # 可变or不可变(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,id就变。不可变==可hash)
# 不可变 列表常用操作
# ======================================基本使用======================================
# 1、用途:按照位置存多个值 # 2、定义方式:在[]内用逗号分隔开多个任意类型的值
l = [111, 3.1, "abc", []] # l=list(...)
# print(type(l)) # 类型转换
# list(传入的可以是任意能够被for循环遍历的类型)
# print(list("hello"))
# print(list(["a",'b']))
# print(list({"k1":11,'K2':222})) # 3、常用操作+内置的方法
# 优先掌握的操作:
# 1、按索引改、取值(正向存取+反向存取):即可改也可以取
# l=[111,222,333,444,555]
# l[0]=1231231231231231231
# print(l) # l[5]=666 # 超出索引范围则报错,即不能用这种赋值操作为列表增加值 # 2、切片(顾头不顾尾,步长)
# l=[111,222,333,444,555]
# res=l[0:3]
# print(res)
# print(l) # 3、长度
# l=[111,222,333,444,555]
# print(len(l))
# 4、成员运算in和not in
# l=[111,222,333,444,555]
# print(111 in l)
# print(111 not in l) # 5、追加
# l=[111,222,333,444,555]
# l.append(666)
# l.append(777)
# print(l) # 5.1 往指定位置前插入值insert
# l.insert(0,123123231231)
# print(l) # 6、删除
# l=[111,"aaa",222,333,444,555]
# a:del是通用的、不是列表专属的删除方式
# del l[0]
# print(l) # b:列表专属的删除方式之指定元素删除
# res=l.remove("aaa")
# print(l)
# print(res) # None # c:列表专属的删除方式之指定索引删除
# l.pop() # 默认删除的是索引-1对应的值
# print(l) # res=l.pop(1)
# print(l)
# print(res) # 7、循环
# l=[111,"aaa",222,333,444,555]
# for item in l:
# print(item) # 需要掌握的操作
# l=[111,222,111,111]
# print(l.count(111)) # l = [10, -1, 3, 2, 11, 7]
# l.sort(reverse=True)
# print(l) # l = [10, -1, 3, 2, 11, 7]
# l.clear()
# print(l) # l=['a',1,'b']
# l.reverse()
# print(l) # l=[11,22,33]
# l.extend([444,555,66])
# print(l) # l.append([444,555,666])
# print(l) l1=[11,22,33]
# l1列表内存存储
# 索引0 值11的内存地址
# 索引1 值22内存地址
# 索引2 值33内存地址 # l2=l1.copy() # 等同于l4=l1[:]
# l2列表内存存储
# 索引0 值11的内存地址
# 索引1 值22内存地址
# 索引2 值33内存地址
# l2[0]=4444
# print(l2) # [4444, 22, 33]
# print(l1) # [11, 22, 33] # l3=l1
# l3[0]=4444
# print(l3)
# print(l1) # ======================================该类型总结====================================
# 存多个值 # 有序 # 可变

day06总结的更多相关文章

  1. day06 Request Response

    rw 读写模板的设置 day05 Request Response 1. HttpServletResponse 简介 1.1 Response 的 OutputStream 输出中文的问题 1.2 ...

  2. python day06笔记总结

    2019.4.3 S21 day06笔记总结 一.昨日内容补充 1.列表独有功能: 1.revers 反转 例:v1 = [1,2,4,88,2] v1.revers() print(v1) 2.so ...

  3. Python基础(正则、序列化、常用模块和面向对象)-day06

    写在前面 上课第六天,打卡: 天地不仁,以万物为刍狗: 一.正则 - 正则就是用一些具有特殊含义的符号组合到一起(称为正则表达式)来描述字符或者字符串的方法: - 在线正则工具:http://tool ...

  4. Day06 DOM4J&schema介绍&xPath

    day06总结 今日内容 XML解析之JAXP( SAX ) DOM4J Schema   三.XML解析器介绍   操作XML文档概述   1 如何操作XML文档 XML文档也是数据的一种,对数据的 ...

  5. python开发学习-day06(模块拾忆、面向对象)

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

  6. 2017-2018-1 JAVA实验站 冲刺 day06

    2017-2018-1 JAVA实验站 冲刺 day06 各个成员今日完成的任务 小组成员 今日工作 完成进度 张韵琪 进行工作总结.博客.小组成员头像 100% 齐力锋 找背按钮声音 100% 张浩 ...

  7. C++Primer笔记-----day06

    ================================================================day06=============================== ...

  8. day06 - Python - 面向对象

    本节内容: 引子 面向对象 v.s. 面向过程 面向对象编程介绍 面向对象的特性:       封装       继承       多态 类.方法   1.引子 假设你现在是一家游戏公司的开发人员,现 ...

  9. 记录我的 python 学习历程-Day06 is id == / 代码块 / 集合 / 深浅拷贝

    一.is == id 用法 在Python中,id是内存地址, 你只要创建一个数据(对象)那么就会在内存中开辟一个空间,将这个数据临时加载到内存中,这个空间有一个唯一标识,就好比是身份证号,标识这个空 ...

  10. day06——小数据池、深浅拷贝、集合

    day06 小数据池 小数据池--缓存机制(驻留机制),只是一种规格,不会实际的开辟一个空间 == 判断两边内容是否相等 ***** # a = 10 # b = 10 # print(a == b) ...

随机推荐

  1. ASP.NET Core 3.1 WebApi+JWT+Swagger+EntityFrameworkCore构建REST API

    一.准备 使用vs2019新建ASP.NET Core Web应用程序,选用api模板: 安装相关的NuGet包: 二.编码 首先编写数据库模型: 用户表 User.cs: public class ...

  2. 关于Graph Convolutional Network的初步理解

    为给之后关于图卷积网络的科研做知识积累,这里写一篇关于GCN基本理解的博客.GCN的本质是一个图网络中,特征信息的交互+与传播.这里的图指的不是图片,而是数据结构中的图,图卷积网络的应用非常广泛 ,经 ...

  3. Photoshop 使用过程中遇到的问题

    1.关于图片像素 根据不同用途设置不同的分辨率: 印洗照片300像素及以上, 高清写真海报96-200像素, 网络图片网页界面72像素, 大型喷绘25到50像素

  4. AutoIt实现文件上传

    AutoIt目前最新是v3版本,这是一个使用类似BASIC脚本语言的免费软件,它设计用于Windows GUI(图形用户界面)中进行自动化操作.它利用模拟键盘按键,鼠标移动和窗口/控件的组合来实现自动 ...

  5. 手写React的Fiber架构,深入理解其原理

    熟悉React的朋友都知道,React支持jsx语法,我们可以直接将HTML代码写到JS中间,然后渲染到页面上,我们写的HTML如果有更新的话,React还有虚拟DOM的对比,只更新变化的部分,而不重 ...

  6. mybatis视频教程2-动态参数

    /MyBatis_04_DynamicSQL/src/com/atguigu/mybatis/dao/EmployeeMapperDynamicSQL.java package com.atguigu ...

  7. DataFrame索引和切片

    import numpy as np import pandas as pd from pandas import DataFrame, Seriesdf = DataFrame(data=np.ra ...

  8. kubernetes资源均衡器Descheduler

    背景 Kubernetes中的调度是将待处理的pod绑定到节点的过程,由Kubernetes的一个名为kube-scheduler的组件执行.调度程序的决定,无论是否可以或不能调度容器,都由其可配置策 ...

  9. Java 比较对象中的内容是否一致

    获取对象中的所有属性 private static Field[] getAllFields(Object object) { Class clazz = object.getClass(); Lis ...

  10. 并发07--线程池及Executor框架

    一.JAVA中的线程池 线程池的实现原理及流程如下图所示: 如上图所示,当一个线程提交到线程池时(execute()或submit()),先判断核心线程数(corePoolSize)是否已满,如果未满 ...