python基础语法 002 - 4 字符串

news2024/11/26 13:32:33

1 字符串

字符串:引号括起来的数据类型

# 双引号
a = "yuze wang"

# 单引号
a = ’yuze wang‘

# 三引号
a = ’‘’yuze‘‘’
a = """yuze"""

注意:所有格式表示都是半角,全角会报错

1.1  引号表示     


#字符串
#引号括起来的数据类型就是字符串
#引号可以是单引号、双引号、三引号

a = "jhfhfhhffhfhfh@#"
print(a)
print(type(a)) 

a = 'jhfhfhhffhfhf'

#三引号 ,可以多行字符串
#三引号,也可以是双引号和单引号
a = """sl
qlk22
99999999999dccc"""

b = """sl
qlk22
99999999999dccc """
print(a)
print(b)

print("""hello""")

#光不溜秋是注释
"""z这是注释"""

运行结果: 

1.2 转义

转义列表

转义序列说明
\(行尾)续行符
\\反斜杠
\'单引号
\"双引号
\a响铃
\b退格(Backspace)
\f换页
\n换行
\r回车
\t水平制表符
\v垂直制表符
\ooo值为八进制 ooo 的字符
\xhh值为十六进制 hh 

 1.3 字符串序列操作

  • 成员运算in, not in 
  • 连接操作 + ,要相同的类型
  • 重复操作 * ,后面加数字
  • 索引操作
  • 切片操作
  • 格式化输出
  • %s, %d, %f, %2f, %d
  • {}
1.3.1 成员运算 in  ,not in

得到的数据类型:布尔类型

#成员运算 in  not in
names = "xiaoming hello world"
print("xiaoming " in names)

print("xiang " in names)

---------- 结果 ----------------------
True
False
1.3.2 连接操作 + 
#+, 字符串可以用 + 号,表示字符串拼接起来
family_name = "wang"
last_name = "chen"
print(family_name + " " + last_name)


——————————————结果 -----------------
wang chen
1.3.3 重复操作 *,

字符串 * 数字,表示重复多少遍

last_name = "chen"
print(last_name * 5)

print("###" * 20)
print("#")
print("###" * 20)

#字符串 * 字符串
print("##" * "##")


------结果 -----
chenchenchenchenchen
############################################################
#
############################################################
Traceback (most recent call last):
  File "F:\pythonProject1\uu.py", line 14, in <module>
    print("##" * "##")
TypeError: can't multiply sequence by non-int of type 'str'
1.3.4 索引操作
#字符串索引,表示获取字符串当中的某 1 个元素
name = "课代表 apple happy开心"

#索引的表示方法:name[索引号]
#在python中索引不是从1开始,而是从0开始
print(name[1])
print(name[7])
print(name[15])
print(name[-1])

------结果 -----
代
l
开
心

len() :读取字符串的长度

索引不能超出范围

#获取字符串长度
name = "课代表 apple happy开心"

print(len(name)) # 17
name_len = len(name) 
print(name[name_len - 1])  # 心


#超出索引范围,报错! IndexError
print(name[name_len]) 

-----结果----
 print(name[name_len])
IndexError: string index out of range
1.3.5 切片操作
A、连续取字符:
name[切的起始点: 切的终点] 取左边不取右边
#字符串切片
#切片:是获取字符串的多个元素
#如何表示:name[切的起始点: 切的终点]
#切片:顾头不顾定,取左不取右,右边要 + 1
name = "课代表 apple happy开心"
print(name[1:2]) #代
print(name[1:3]) #代表
B、间隔取:步长
name[切的起始点: 切的终点:步长]

步长:step获取第一次后,加多少个索引取获取第二次

#name[切的起始点: 切的终点:步长]
num = "01010101010101010101"
print(num[0: 5 : 2])
print(num[1: 5 : 2]) # 1 +2 +2


---结果--
000
11
C、方向
  • 步长为正数:从左往右
  • 步长为负数:从右往左
#倒序
name = "课代表 apple happy开心"
print(name[::-1])

————-结果 ----
心开yppah elppa 表代课

#步长是可以省略的,step默认为1
name = "课代表 apple happy开心"
print(name[2 : 3])

#start 可以省略?
#start省略,从最开始的地方,0 或 -1
print(name[ : 3])

#end 可以省略?
#end省略,一直取到最后
print(name[1 : ])
#vs name[1 : -1]
print(name[1 : -1])

#start 和 end 可以省略?
#全部取完,从开始到最后
#name[:] 可以复制原来的文本
print(name[: ])
print(name)

#步长step ,开始位置 > 结束位置
print("打印结果".format(name[3: 0]))

------结果 ----------------------
表
课代表
代表 apple happy开心
代表 apple happy开
课代表 apple happy开心
课代表 apple happy开心
打印结果
#步长方向
name = "课代表 apple happy开心"
print(name[0:3 :1])
print("打印结果{}".format(name[3 :0:1])) #指令矛盾了,不知道听谁的了
print("打印结果{}".format(name[3 :0: -1]))
print("打印结果{}".format(name[2 :4: -2]))
print("打印结果{}".format(name[4 :1: -1]))
print("打印结果{}".format(name[4 :4: -1]))#指令矛盾了,不知道听谁的了
print("打印结果{}".format(name[-2 :-6: -2]))

-----结果 -----
课代表
打印结果
打印结果 表代
打印结果
打印结果a 表
打印结果
打印结果开p

 总结:什么时候才能取到数

1、end - step 判断是正数还是负数

2、step 是正数还是负数

3、end - start与step要同正、同负,否则打印不出结果,如果计算结果出现冲突,则就为空

D、超出范围怎么办?

在切片当中,超出范围,是不报错的,是表示取完的意思

#范围超出
name = "课代表 apple happy开心"
print(name[1 : 10000])

------结果----
代表 apple happy开心
1.3.6 格式化输出
name = "课代表"

###
#课代表
####
print("### * 4")
print("# " + " " + name)
print("### * 4")


#方法二 {} 占位符用来占位置, .format 格式化输出,占位符和变量要匹配,一一对应,变量名可以多但不能少于占位符
name = input("name: ")

print("小葱拌豆腐:一清二白:{}".format(name))


-----结果 ----
### * 4
#  课代表
### * 4
name: 巧克力
小葱拌豆腐:一清二白:巧克力

#错误表述
print("""
### * 4
# + ' ' + name
### * 4 
""")

----结果 ----
### * 4
# + ' ' + name
### * 4 

补充说明:占位符 的数量需要和变量一一对应,占位符数量< = 格式化输出的变量

 格式化输出采用以下方式: 

#方法一:
name = input("name: ")
age = input("age:")
gender = input("gender:")
print("小葱拌豆腐:一清二白:{}".format(name))

print("""
小葱拌豆腐:一清二白{}
年龄:{}
性别:{}
""".format(name, age, gender))

-----结果 ----
小葱拌豆腐:一清二白:巧克力

小葱拌豆腐:一清二白巧克力
年龄:哇哈哈89
性别:99


#方法二
#位置索引, 要全部传,如果存在其中一个占位符没有传就会报错,从0 开始
print("""
小葱拌豆腐:一清二白:{2}
年龄:{1}
性别:{2}
""".format(name, age, gender))

-----结果 ----
小葱拌豆腐:一清二白:99
年龄:哇哈哈89
性别:99


#方法三
#关键字取值,标记取值,用于变量多的情况加标记,比较少用
print("""
小葱拌豆腐:一清二白{username}
年龄:{aging}
性别:{gendering}
""".format(username =name, aging= age, gendering=gender))


-----结果 ----
小葱拌豆腐:一清二白巧克力
年龄:哇哈哈89
性别:99



1.3.7 字符串函数
  • 大小写转换 lower() upper()
  • 大小写互换 swapcase()
  • 首字母大写title(), capitalize()
  • 替换 replace(old, new)
  • 查找元素find() 没有找到就返回-1, index(), 会报错
  • 数 count()
  • isdigital()
  • islower()
  • join()
  • split()
  • strip()
a = "hello WOrld"
print(a.upper())
print(a.lower())
print(a.title())
print(a.capitalize())
print(a.swapcase())

---- 结果 ---
HELLO WORLD
hello world
Hello World
Hello world
HELLO woRLD
#replace() 替换每个字符
a = "王婆卖瓜 - 自卖自夸"
b = a.replace("王婆", "哇哈哈")
print(b)

#find 查找指定字符, ===》得到为找到该字符串的索引位置
index = a.find("瓜")
print(index)

#find 查找指定字符, ===》不能找到,返回-1
index = a.find("西")
print(index)

#index  == find
rssult = a.index("瓜")
print(rssult)

#index 方法如果找不到就会报错
# ValueError, 值错误
# rssult = a.index("西")
# print(rssult)

--报错:
--rssult = a.index("西")
--ValueError: substring not found

#count() 查找字符的次数,进行数据分析
# 统计某个歌词出现的次数
song = """静止了所有的花开遥远了 
清晰了爱天郁闷 爱却很喜欢那时候我不懂这叫爱你喜欢 
站在那窗台你好久 都没再来彩色的时间染上空白是你流的泪晕开"""
res = song.count("你")
print(res)

#join() 字符串拼接的高级用法,可以用做测试用例数据的方法 ====》 CSV
a = ",".join(["http://ss.com.cn","GET", "lucky", "123456"])
print(a)

#split() 拆开, 拆开后,通过索引获取单个测试数据
b = a.split("#")
print(b)

#strip() 进行字符串去掉空格,只能去除两边的空格
world = '    sole abc v'
c = world.strip()
print(c)

#isdigital()是否是正整数
print(c.isdigit())

#islower() 是否是个小写
print(c.islower())

-----结果 ---- 
哇哈哈卖瓜 - 自卖自夸
3
-1
3
3
http://ss.com.cn,GET,lucky,123456
['http://ss.com.cn,GET,lucky,123456']
sole abc v
False
True

Process finished with exit code 0

1.4 总结: 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1833663.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++及cmake语法介绍

c/cmake学习 文章目录 c/cmake学习1. c1.1 基本模型1.1.1 for循环1.1.2 main函数1.1.2 带参数函数编译函数 2. CMAKE2.1 相关命令2.1.1 编译基本命令2.1.2 动态库静态库编译2.1.3 消息输出2.1.4 cmake变量常见参数1. 设置构建类型2. 设置编译器标志3. 指定编译器4. 设置安装路径…

【PB案例学习笔记】-22制作一个语音朗读金额小应用

写在前面 这是PB案例学习笔记系列文章的第22篇&#xff0c;该系列文章适合具有一定PB基础的读者。 通过一个个由浅入深的编程实战案例学习&#xff0c;提高编程技巧&#xff0c;以保证小伙伴们能应付公司的各种开发需求。 文章中设计到的源码&#xff0c;小凡都上传到了gite…

计算机网络:3数据链路层

数据链路层 概述封装成帧和透明传输帧透明传输&#xff08;填充字节或比特&#xff09;差错检测奇偶校验循环冗余校验CRC Cyclic Redundancy Check 可靠传输停止-等待协议回退n帧协议&#xff08;滑动窗口协议&#xff09;选择重传协议 点对点协议PPP共享式以太网网络适配器&am…

Spring系统学习 -Spring IOC 的XML管理Bean之P命名空间、实现引入MySQL外部链接属性文件

P命名空间 在Spring框架中&#xff0c;P命名空间是一种用于简化XML配置文件中属性注入的方式。通过引入P命名空间&#xff0c;可以使用更简洁的语法来设置bean的属性值&#xff0c;而无需显式地使用<property>子元素。这使得XML配置文件更加简洁和易于阅读。 要在Sprin…

【vue3|第9期】Vue3中watch监视的深度解读

日期&#xff1a;2024年6月10日 作者&#xff1a;Commas 签名&#xff1a;(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释&#xff1a;如果您觉得有所帮助&#xff0c;帮忙点个赞&#xff0c;也可以关注我&#xff0c;我们一起成长&#xff1b;如果有不对的地方&#xf…

期末复习GGG-----查找子串

郭的 char *search( char *s, char *t ){int i0;while(s[i]){int j0;if(s[i]t[0]){while(s[ij]t[j]&&t[j]){j;}if(t[j]\0)return si;}i;}return NULL; } AI的 #include <stdio.h> #include <string.h> #define MAXS 30char *search(char *s, char *t);in…

Matlab使用Simulink仿真实现AM和BPSK信号的解调

前言 本篇实现了基于AM和BPSK调制的通信系统&#xff0c;采用Bernoulli Binary Generator生成随机二元序列&#xff0c;码元速率为0.5秒/个。AM调制使用Sine Wave模块生成载波&#xff0c;频率40Hz&#xff0c;相位π/2。BPSK调制通过Switch模块切换相位0和π的载波。信号传输…

红利之外的A股底仓选择:A50

内容提要 华泰证券指出&#xff0c;当前指数层面下行风险不大&#xff0c;市场再入震荡期下&#xff0c;可关注三条配置线索&#xff1a;1&#xff09;A50为代表的产业巨头&#xff1b;2&#xff09;以家电/食饮/物流/出版为代表的稳健消费龙头&#xff0c;3&#xff09;消费电…

使用 Iceberg、Tabular 和 MinIO 构建现代数据架构

现代数据环境需要一种新型的基础架构&#xff0c;即无缝集成结构化和非结构化数据、轻松扩展并支持高效的 AI/ML 工作负载的基础架构。这就是现代数据湖的用武之地&#xff0c;它为您的所有数据需求提供了一个中心枢纽。然而&#xff0c;构建和管理有效的数据湖可能很复杂。 这…

【离散化 二维差分】850. 矩形面积 II

本文涉及知识点 离散化 二维差分 LeetCode850. 矩形面积 II 给你一个轴对齐的二维数组 rectangles 。 对于 rectangle[i] [x1, y1, x2, y2]&#xff0c;其中&#xff08;x1&#xff0c;y1&#xff09;是矩形 i 左下角的坐标&#xff0c; (xi1, yi1) 是该矩形 左下角 的坐标…

物联网协议基础知识

协议允许节点以结构化的方式在它们之间进行交互。由于物联网设备的需求和用例在过去几年中迅速发展&#xff0c;协议也随之发展。总而言之&#xff0c;主要有两类协议&#xff1a;网络协议和数据协议。此分类来自广泛应用于 IT 通信网络的 OSI&#xff08;开放系统互连&#xf…

深入探讨JavaScript的执行机制

预编译 首先下面这段代码的执行是一个怎样的结果呢&#xff1f; showName(); console.log(MyName);var MyName 小陈同学function showName() {console.log(函数showName被执行); }在这段代码中我们声明了一个变量MyName和一个函数showName&#xff0c;调用函数&#xff0c;打…

TWM论文阅读笔记

这是ICLR2023的一篇world model论文&#xff0c;用transformer来做世界模型的sequence prediction。文章贡献是transformer-based world model&#xff08;不同于以往的如transdreamer的world model&#xff0c;本文的transformer-based world model在inference 的时候可以丢掉…

手机usb共享网络电脑没反应的方法

适用于win10电脑&#xff0c;安卓手机上可以 开启usb网络共享选择&#xff0c;如果选择后一直跳&#xff0c;让重复选择usb选项的话&#xff0c;就开启 开发者模式&#xff0c;进到 开发者模式 里设置 默认usb 共享网络 选项 &#xff0c;就不会一直跳让你选。 1.先用数据线 连…

一款.NET开源、功能强大、跨平台的绘图库 - OxyPlot

前言 今天大姚给大家分享一款.NET开源&#xff08;MIT License&#xff09;、免费、跨平台、功能强大的绘图库&#xff0c;支持多平台使用&#xff08;包括&#xff1a;WPF、UWP、WinForm、Silverlight、Xamarin.iOS、Xamarin.Android、Xamarin.Forms 和 Xamarin.Mac等&#x…

Disk /dev/sda: 107.4 GB, 107374182400 bytes, 209715200 sectors

Disk /dev/sda: 107.4 GB, 107374182400 bytes, 209715200 sectors 块设备名称为&#xff1a; /dev/sda 设备的大小为&#xff1a;107.4 GB 107374182400 bytes &#xff1a; 107374182400/1024/1024/1024100G &#xff08;1&#xff09;块设备名称为&#xff1a;/dev/sd…

DS18B20温度传感器完整使用介绍(配合51单片机)

DS18B20是一款由Maxim Integrated&#xff08;原Dallas Semiconductor&#xff09;生产的数字温度传感器&#xff0c;以其高精度、低功耗、灵活的接口方式和易于使用的特性&#xff0c;在各种温度监测应用中被广泛采用。 以下是DS18B20的详细介绍&#xff1a; 基本特性 数字输…

【CSS in Depth2精译】1.1 层叠

CSS 本质上就是声明规则&#xff0c;并让这些特定的规则在各种情况下生效。一个类添加到某个元素上&#xff0c;则应用这个类包含的这一些样式&#xff1b;元素 X 是元素 Y 的一个子节点&#xff0c;则应用另一些样式。浏览器于是根据这些规则&#xff0c;判定所有样式生效的具…

数据结构-十大排序算法集合(四万字精讲集合)

前言 1&#xff0c;数据结构排序篇章是一个大的工程&#xff0c;这里是一个总结篇章&#xff0c;配备动图和过程详解&#xff0c;从难到易逐步解析。 2&#xff0c;这里我们详细分析几个具备教学意义和实际使用意义的排序&#xff1a; 冒泡排序&#xff0c;选择排序&#xff0c…

解决安全规模问题:MinIO 企业对象存储密钥管理服务器

在强大可靠的存储解决方案领域&#xff0c;MinIO 作为持久层脱颖而出&#xff0c;为组织提供安全、持久和可扩展的存储选项。MinIO 通常负责处理关键任务数据&#xff0c;在确保高可用性方面发挥着至关重要的作用&#xff0c;有时甚至在全球范围内。存储数据的性质&#xff0c;…