字符串

字符串是不可变的对象,任何操作对原字符串是不会有任何影响的.

索引和切片

  1. 索引 . 索引就是下标, 下标从 0 开始, 使用[] 来获取数据
  • s1 = "0123456"
  • print(s1[X]) 获取第X个,若X为负,则从倒数开始.
  1. 切片 我们可以使用下标来截取部分字符串的内容

    语法: str[start: end:step]

    规则: 顾头不顾尾,从start开始截取,截取到end位置,但不包括end.

    跳着截取

    print(str[start:end:step] # step表示步长,如果步长是正数,从左往右,负数则从右往左.表示每多少个取一个

字符串的相关操作方法

  1. 大小写转来转去

    s = s1.capitalize()   #首字母大写
    s = s1.lower () #全部转换成小写
    s = s1.upper () #全部转换成大写
    while True:
    content = input("请输入内容")
    if content.upper == "Q"
    break
    print(content)
    s = s1.swapcase()   # 大小写互换
    s= s1.casefold() #不常用,转成小写,和lower的区别: lower()对某些字符支持不够好,casefold() 对所有字母都有效
    s = s1.title() #每个首字母大写
  2. 切来切去

    s = s1.center(10, "*")    #居中,把原来的字符拉长成10,其余位置补 *
    s = s1.strip() #去掉左右两端的空格 也可以去掉指定元素
    s= s1.lstrip() #去掉左边空格
    s= s1.rstrip() #去掉右边空格
    s = s1.replace('a', 'b', X) #字符串替换,把a替换成b, X 是替换次数
    s = s1.split() #字符串切割, 默认是空格分割 如果切割福在两端,会出现空字符串( " ") 分割后返回的内容是列表
    print(" 1 2 3 4 \n 5 6 7")   \n  是换行
    
       用于模拟登陆,忽略用户输入的空格
    
       ```python
    count = 1
    while count <= 3:
    username = input("用户名:").strip()
    password = input("密码").strip()
    if username == "Agoni" and password == "123":
    print("登陆成功")
    break
    else:
    print("用户名或者密码错误")
    print("已经登录%s次,剩余%s次" % (count, 3-count))
    count = count + 1
  3. 格式化输出

    s1 = "我叫%s, 今年%d岁了, 我喜欢%s" % ('sylar', 18, '周杰伦')  # 之前的写法
    
    #  % 占位符: 声明占位的类型 %s -- 字符串  %d/%i -- 整型  %% 转义 成为普通的%   %() 不能多,不能少,一一对应
    
    name = input("name")
    print(f"alex{name},{'aaa'}")
    # 打印结果是 alexname,aaa
    # f"{}" 大括号里的内容一般都放变量 字符串单引号 3.6版本及以上才能使用 s1 = "我叫{}, 今年{}岁了, 我喜欢{}".format("周杰伦", 28, "周润发") # 按位置格式化 顺序填充 s1 = "我叫{0}, 今年{2}岁了, 我喜欢{1}".format("周杰伦", "周润发", 28) # 指定位置 索引填充 s1 = "我叫{name}, 今年{age}岁了, 我喜欢{singer}".format(name="周杰伦", singer="周润
    发", age=28) # 指定关键字
  4. 查找

    s = s1.startswith("XXX") # 判断是否以XXX开头
    
    s = s1.endswith("XXX") # 是否以'XXX'结尾
    
    s = s1.count("a") # 查找"a"出现的次数
    
    s = s1.find("xxx") # 查找'xxx'的位置, 如果没有返回-1
    
    s = s1.find("a", 8, 22) # 切⽚找
    
    s = s1.index("xxx") # 求索引位置. 注意. 如果找不到索引. 程序会报错
    
    
  5. 条件判断

    # 条件判断
    s1 = "123.16"
    s1 = "abc"
    s1 = "_abc!@"
    # 是否由字⺟和数字组成
    print(s1.isalnum()) # 是否由字⺟组成
    print(s1.isalpha()) # 是否由数字组成, 不包括小数点
    print(s1.isdecimal()) # 记这个 判断十进制 返回布尔值
    print(s1.isdigit())
    print(s1.isnumeric()) # 这个⽐较牛B. 中⽂都识别.
  6. 字符串长度

    s1 = " XXXX,XXXXXX "
    s = len(s1) # 计算字符串的⻓度
    注意: len()是python的内置函数. 所以访问方式也不一样. 你就记着len()和print()一样就⾏

Python基础篇 -- 字符串的更多相关文章

  1. python基础篇----字符串unicode

    python中处理中文常要用到unicode,因为较容易遇到字符串编码的问题,我一般都是将字符串统一转成unicode去处理 python中定义一个unicode字符串,可以在字符串前面加u: str ...

  2. python基础篇-day1

    python基础篇 python是由C语言写的: pass 占位符: del,python中全局的功能,删除内存中的数据: 变量赋值的方法: user,pass = 'freddy','freddy1 ...

  3. Python基础数据类型-字符串(string)

    Python基础数据类型-字符串(string) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版 ...

  4. python基础篇之进阶

    python基础篇之进阶 参考博客:http://www.cnblogs.com/wupeiqi/articles/5115190.html python种类 1. cpython  使用c解释器生产 ...

  5. python基础篇(六)

    PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...

  6. python基础篇(一)

    PYTHON基础篇(一) 变量 赋值 输入,输出和导入 A:输入 B:输出 C:导入 运算符 A:算数运算符 B:比较运算符 C:赋值运算符 D:位运算符 E:逻辑运算符 F:成员运算符 G:身份运算 ...

  7. python基础篇(三)

    PYTHON基础篇(三) 装饰器 A:初识装饰器 B:装饰器的原则 C:装饰器语法糖 D:装饰带参数函数的装饰器 E:装饰器的固定模式 装饰器的进阶 A:装饰器的wraps方法 B:带参数的装饰器 C ...

  8. python基础篇(四)

    PYTHON基础篇(四) 内置函数 A:基础数据相关(38) B:作用域相关(2) C:迭代器,生成器相关(3) D:反射相关(4) E:面向对象相关(9) F:其他(12) 匿名函数 A:匿名函数基 ...

  9. Python基础篇--输入与输出

    站长资讯平台:Python基础篇--输入与输出在任何语言中,输入和输出都是代码最基础的开始,so,先来聊一聊输入和输出输出输入END在任何语言中,输入和输出都是代码最基础的开始,so,先来聊一聊输入和 ...

随机推荐

  1. 668. Kth Smallest Number in Multiplication Table

    Nearly every one have used the Multiplication Table. But could you find out the k-th smallest number ...

  2. Lightoj 1129【字典树】

    题意:如果存在一个串是另一个串的公共前缀就是NO,否则就是YES 思路:利用字典树的特性搞搞就好了 #include <bits/stdc++.h> using namespace std ...

  3. 强大的在线web编辑器UEditor

    UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码. UEditor在线演示地址:http://u ...

  4. 后台管理系统·快速开发框架JSite

    平台介绍 框架基于Maven构建,拆分成多个子模块,层次结构清晰.可用于所有Web应用,如企业后台管理系统.OA系统.CMS.CRM等. 框架本身集成了最新的 Flowable工作流引擎 https: ...

  5. 使用JMETER进行REST API测试(分步指南)

    我确定你在这里是因为你需要加载测试Json Rest API.这并不奇怪,因为Rest API现在越来越受欢迎. 这本指南的目的:帮助您进行负载测试一个Json的 REST API 通过一个具体的例子 ...

  6. Zynq7000开发系列-4(新:Xilinx交叉编译环境搭建)

    一.前言  本来上一篇文章已经讲了Xilinx交叉编译环境的搭建,但是我在后续的使用中发现:使用2011年版本的交叉编译链编译OpenCV 3.1.0时出现错误: 网络搜索一番,查明是交叉编译链的问题 ...

  7. scrapy框架中Spiders用法

    scrapy框架中Spiders用法 Spider类定义了如何爬去某个网站,包括爬取的动作以及如何从网页内容中提取结构化的数据 总的来说spider就是定义爬取的动作以及分析某个网页 工作流程分析 以 ...

  8. Elasticsearch之安装

    elasticsearch需要java8以上支持 java -version 二进制文件下载 www.elastic.co/downloads tar安装示例 1.下载tar文件 curl -L -O ...

  9. 关于@Mapper和@Repository的一点小理解

    参考博客:https://blog.csdn.net/lalioCAT/article/details/51803461 如果在接口上@Mapper,然后再在 xml中的namespace指向mapp ...

  10. Python临时笔记

    动态语言python的特性 python2  输入一个匿名函数直接执行 # coding=utf-8 def Test(a, b, func): result = func(a, b) return ...