python基础学习(十)字符串

字符串的定义

  • 字符串 就是 一串字符,是编程语言中表示文本的数据类型
  • 在 Python 中可以使用 一对双引号 " 或者 一对单引号 ‘ 定义一个字符串
    • 虽然可以使用 \" 或者 \‘ 做字符串的转义,但是在实际开发中:

      • 如果字符串内部需要使用 ":,可以使用 ‘ 定义字符串,例如:‘zhangsan "hello" ‘
      • 如果字符串内部需要使用 ‘,可以使用 " 定义字符串
  • 可以使用 索引 获取一个字符串中 指定位置的字符,索引计数从 0 开始
  • 也可以使用 for 循环遍历 字符串中每一个字符

    str1 = "Hello world"
    print(str1)
    
    for char in str1:
    
        print(char)
  • 一般情况下,使用双引号"来定义字符串(大多数的编程语言都是使用的双引号")

字符串的常用操作

  • 在ipython3中,定义一个字符串,例如:my_str = ""
  • 输入 my_str. 并按下Tab键,ipython3会提示字符串能使用的方法如下:


    可以看到字符串中的方法还是很多的。
  1.  先看一下字符串中的统计和求索引的相关操作:len(str)、 str.count(str2)、str.index(str2)

    my_str = "hello world, hello"
    
    # 1. 统计字符串长度
    
    print(len(my_str))
    
    # 2. 统计某一子串出现的次数
    
    print(my_str.count("ell"))
    print(my_str.count("cda"))
    
    # 3. 求某一子字符串的索引
    print(my_str.index("wor"))
    # 注意,如果子字符串没有找到,程序会报错
    print(my_str.index("cba"))
  2. 判断类型的方法如下:


    涉及到的方法比较多,对其中的一部分方法进行练习:

    # 1. 判断空白字符
    space_str = " \t\r\n"
    print(space_str.isspace())
    
    # 2. 判断是否为数字
    
    num_str1 = "12"
    print(num_str1)
    print(num_str1.isdecimal())
    print(num_str1.isdigit())
    print(num_str1.isnumeric())
    
    num_str2 = "1.2"
    print(num_str2)
    print(num_str2.isdecimal())
    print(num_str2.isdigit())
    print(num_str2.isnumeric())
    
    num_str3 = "\u00b2"
    print(num_str3)
    print(num_str3.isdecimal())
    print(num_str3.isdigit())
    print(num_str3.isnumeric())
    
    num_str4 = "一零零二"
    print(num_str4)
    print(num_str4.isdecimal())
    print(num_str4.isdigit())
    print(num_str4.isnumeric())
    
    # 3. 大小写判断
    print("abc".islower())
    print("ABC".isupper())
  3. 查找和替换

    my_str = "hello world"
    
    # 1. 判断字符串是否以指定字符串开始
    print(my_str.startswith("hell"))
    
    # 2. 判断字符串是否以指定字符串结尾
    print(my_str.endswith("orld"))
    
    # 3. 查找指定字符串
    
    print(my_str.find("llo"))
    # 查找的字符串不存在,则返回-1
    # index方法查找的字符串不存在会报错
    print(my_str.find("abc"))
    
    # 4.字符串替换
    print(my_str.replace("world", "zfx"))
  4. 大小写转换

    # 1. 转大写
    
    print("abc".lower())
    
    # 2. 转小写
    
    print("ABC".upper()) 
  5. 文本对齐

    my_str = "hello world"
    
    # 1. 左对齐
    print("|%s|" % my_str.ljust(20, " "))
    
    # 2. 右对齐
    print("|%s|" % my_str.rjust(20, " "))
    
    # 3. 居中对齐
    print("|%s|" % my_str.center(20, " "))
  6. 去除空白字符


  7. 拆分和连接

    my_str = "hello world\nhello zfx"
    
    print(my_str)
    
    # 1. 拆分字符串
    
    str_list = my_str.split()
    print(str_list)
    
    # 2. 字符串拼接
    
    result = " ".join(str_list)
    print(result)  

字符串切片

  • 切片 方法适用于 字符串列表元组

    • 切片 使用 索引值 来限定范围,从一个大的 字符串切出 小的 字符串
    • 列表元组 都是 有序 的集合,都能够 通过索引值 获取到对应的数据
    • 字典 是一个 无序 的集合,是使用 键值对 保存数据
  • 语法:

    字符串[开始索引:结束索引:步长]

  需要注意的地方:

  • 指定的区间属于 左闭右开[开始索引, 结束索引) => 开始索引 >= 范围 < 结束索引

    • 起始 位开始,到 结束位的前一位 结束(不包含结束位本身)
  • 从头开始,开始索引 数字可以省略,冒号不能省略
  • 到末尾结束,结束索引 数字可以省略,冒号不能省略
  • 步长默认为 1,如果连续切片,数字和冒号都可以省略

  索引的顺序和倒叙

  • 在 Python 中不仅支持 顺序索引,同时还支持 倒序索引
  • 所谓倒序索引就是 从右向左 计算索引
    • 最右边的索引值是 -1,依次递减
  • 例子练习:

    num_str = "0123456789"
    # 1. 截取从 2 ~ 5 位置 的字符串
    print(num_str[2:6])
    
    # 2. 截取从 2 ~ 末尾 的字符串
    print(num_str[2:])
    
    # 3. 截取从 开始 ~ 5 位置 的字符串
    print(num_str[:6])
    
    # 4. 截取完整的字符串
    print(num_str[:])
    
    # 5. 从开始位置,每隔一个字符截取字符串
    print(num_str[::2])
    
    # 6. 从索引 1 开始,每隔一个取一个
    print(num_str[1::2])
    
    # 7. 截取从 2 ~ 末尾 - 1 的字符串
    print(num_str[2:-1])
    
    # 8. 截取字符串末尾两个字符
    print(num_str[-2:])
    
    # 9. 字符串的逆序(面试题)
    print(num_str[::-1])
    

--本文完--

原文地址:https://www.cnblogs.com/zhangfengxian/p/python-string.html

时间: 2024-10-28 14:22:36

python基础学习(十)字符串的相关文章

Python基础学习(十)

Python I/O模型 同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么区别?不同的人在不同的上下文下给出的答案是不同的.所以先限定一下本文的上下文. 概念说明 在进行解释之前,首先要说明几个概念: 用户空间和内核空间 进程切换 进程的阻塞 文件描述符 缓存 I/O 用户空间与内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方).操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的内存空间,也有访问底层硬件

python基础学习07(核心编程第二版)部分

# -*- coding: utf-8 -*- # ==================== #File: python #Author: python #Date: 2014 #==================== __author__ = 'Administrator' #file与input output #文件对象 #简单说来,就是写入和读取的方式 #file(),open()2个操作都是一样的,一般推荐open() #语法 # open(name[, mode[, bufferin

python基础学习08(核心编程第二版)部分

# -*- coding: utf-8 -*- # ==================== #File: python #Author: python #Date: 2014 #==================== __author__ = 'Administrator' #异常 """ NameError: 尝试访问一个未申明的变量 ZeroDivisionError:  除数为零 SyntaxError: 解释器语法错误 IndexError: 请求的索引超出序列范

python基础学习12(核心编程第二版)部分

# -*- coding: utf-8 -*- # ==================== #File: python #Author: python #Date: 2014 #==================== __author__ = 'Administrator' #python class #面向对象编程oop思想,3个特性:封装.继承.多态,在其他方面的功能,比如重载,模拟等,也可以自定义自己需要的类 #在python中,面向对象主要2个:类和类实例 #类与实例 #类与实例有关

python基础学习11(核心编程第二版)部分

# -*- coding: utf-8 -*- # ==================== #File: python #Author: python #Date: 2014 #==================== __author__ = 'Administrator' #执行环境 #可调用对象 """ 许多的python 对象都是我们所说的可调用的,即是任何能通过函数操作符“()”来调用的对象.要调用可调用对象, 函数操作符得紧跟在可调用对象之后.Python 有4

萌新向Python数据分析及数据挖掘 第一章 Python基础 第十节 文件和异常

第一章 Python基础 第十节 文件和异常 从文件中读取数据 读取文件.文件路径   1 filename = 'pi_digits.txt' #文件名取个代号 2 #读取整个文件 3 with open(filename) as file_object: 4 contents = file_object.read()# 给内容取个代号 5 print(contents.rstrip()) 6 #逐行读取 7 with open(filename) as file_object: 8 for

python基础学习2

python中的运算符 1.算术运算符:用来做算术运算的符号 ①.+ :求和,也可以做连接符 ②. - :求差 ③. * : 求积 ④. / :求商 ⑤.% :取余 ⑥.//  :取整 ⑦.**  :次方 注意:只能是数值 print(3*3) #求积结果:9 print(9/2) #相除结果:4.5 print(3**4) #3的4次方,结果:81 print(9//4) #小数部分直接丢掉,取整结果:2 print(13%3) #取余结果:1 运行结果是 9 4.5 81 2 1 比较运算符

Python基础学习五

Python基础学习五 迭代 for x in 变量: 其中变量可以是字符串.列表.字典.集合. 当迭代字典时,通过字典的内置函数value()可以迭代出值:通过字典的内置函数items()可以迭代出键值对. for key in dict: #迭代键 for val in dict.value(): #迭代值 for k,v in dict.items(): #迭代键值对 当迭代列表时,通过内置函数enumerate()可以迭代出索引加值. for i in list #迭代列表 for i

python基础学习日志day5-各模块文章导航

python基础学习日志day5---模块使用 http://www.cnblogs.com/lixiang1013/p/6832475.html python基础学习日志day5---time和datetime模块 http://www.cnblogs.com/lixiang1013/p/6848245.html python基础学习日志day5---random模块http://www.cnblogs.com/lixiang1013/p/6849162.html python基础学习日志da

Python 基础学习 网络小爬虫

<span style="font-size:18px;"># # 百度贴吧图片网络小爬虫 # import re import urllib def getHtml(url): page = urllib.urlopen(url) html = page.read() return html def getImg(html): reg = r'src="(.+?\.jpg)" pic_ext' imgre = re.compile(reg) imgli