python-day3

字符串

1.什么是字符串

  • 使用单引号或者双引号括起来的字符集就是字符串。

  • 引号中单独的符号、数字、字母等叫字符。

  • 转义字符:可以用来表示一些有特殊功能或者是特殊意义的字符(通过在固定的字符前加)
    \ ' ->'
    \ \ -> \
    \n ->换行
    \t ->制表符
    \ "-> "
    说明:在计算字符串长度时,转义字符代表一个字符。

str2='\''
print(str2)
str1='床前明月光,\n疑是地上霜'
print(str1)

结果:
'
床前明月光,
疑是地上霜

2.阻止转义(python专有)

可以通过在字符串前面加r(R)来阻止转义字符转义。

str1=r'\'' 
print(str1)

结果
\'

3.python中字符串中的编码方式是Unicode编码。

  • Unicode编码:使用16位对一个字符编码。
  • 编码目的:让字符可以存储到计算机中。
    -Unicode码中包含了ASSCII码,可以表示世界上所有的语言和符号。

a.获取一个字符的Unicode码

print(ord('w'),ord('s'),ord('w'))

结果:
119 115 119

b.将Unicode码转换成字符

chr(编码值)

print(chr(0x5434))


结果:
吴

字符串比较大小时,从字符开始依次往后比较每个字符的大小,直到遇到字符不一样为止。
比较字符大小时,实质比的是他们编码的大小。

print('abc'>'b')
结果:
False

2.获取字符串的字符

python的字符串,实质是一个有序的字符序列。

1.获取字符串长度:(长度->字符串中字符的个数)

len是获取序列长度的内置函数。

count=len('abc\n123')
print(count)

结果:
7

2.通过下标获取字符串中的某一个字符。

字符串中每个字符都对应一个下标(索引),我们可以通过索引值去获取固定的字符。
'abc' ---> a:0,b:1,c:2

str1='abc'
print(str1[0])  #a
print(str1[2])  #c

结果:
a
c

下标范伟: 0 - 字符串长度-1;-1~负的字符串长度
获取字符时,索引值不能超过索引的范围,否则会报IndexError错误。

str2='good good study\nday day up'
print(str2[25])
print(str1[-1])  #获取字符串str1中的最后一个字符
print(str1[-2])  #获取字符串str1中的倒数第二个字符

结果:
p
c
b

3.获取字符串中的部分字符(切片):

字符串[开始下标:结束下标]
--->获取字符串中从开始下标到结束下标的字符(包含开始下标对应的字符,不包含结束下标对应的字符)
字符串[开始下标:结束下标:步进]

字符串[开始下标:结束下标] == 字符串[开始下标:结束下标:1]

  • a.开始和结束下标都有值:开始下标对应的字符,要在结束下标对应的字符前面(步进是正数)。
str3=('hello python')
str4=print(str3[6:12])   # python
str4=print(str3[-6:12])  # python

结果:
python
python
  • b.开始下标省略:从字符串的最前面取到结束下标前。
print(str3[:4])

结果:
hell
  • c.结束下标省略:从开始位置获取到字符串结束。
print(str3[4:])

结果:
o python

  • d.两个都省略:获取整个字符串的内容。
print(str3[:])

结果:
hello python
  • e.(了解)当步进是复数的时候,开始下标和结束下标的性质相反
print(str3[::2]) #lhopto  
print(str3[6:1:-1]) #p oll
print(str3[::-1])  #字符串倒序

结果:
hlopto
p oll
nohtyp olleh

3.字符串运算符

1.+:字符串拼接

字符串1+字符串2

str1='hello'
str2='python'
print(str1+' '+str2)

结果:
hello python

注意:+号两边要么都是数字,要么都是字符串。不能一个数字一个字符串。
print(12+'ad') #TypeError: unsupported operand type(s) for +: 'int' and 'str'

2. *:让字符串重复

字符串*整数

print(str1*3)

结果:
hellohellohello

3. in:

字符串1 in 字符串2:判断字符串1是否在字符串2中 -->在是True,不在是False

result='aa' in 'abac'
print(result)

结果:
False

4. not in

字符串1 not in 字符串2:判断字符串1是否不在字符串2中 -->不在就是True,在是False

result='aa' not in 'abac'
print(result)

结果:

True

5.格式字符串 %s(占位符)

格式:'占位符1占位符2' % (值1,值2)

str1='abc%s12%s3' % ('>>>','!!!')

print(str1)

结果:
abc>>>12!!!3f10
  • %s -->字符串占位符(格式符)
  • %d -->整数占位符(格式符)
  • %f -->浮点数占位符
  • %c -->长度是1的字符串占位符(字符占位符)--可以给一个字符,也可以给字符的编码值
str2='%s%d%f%c' % ('我是字符串',123,12.4,'k')
print(str2)

结果:
我是字符串12312.400000k
  • %.nf:使用n值限制小数点后面的小数位数(默认六位小数)
str3='金额:%.2f元' % (100)
print(str3)

结果:
金额:100.00元

如果后面没有加上%,那么这个字符是一个普通的字符串

str3='金额:%f元'
print(str3)

结果:
金额:%f元
  • %x和%X -->十六进制数据占位符
    XXX的十六进制是XXXXXX
str4='%d的十六进制是%x' % (number,number)
print(str4)

结果:
100的十六进制是64

6.格式化输出

name='XXX'
age=18
print('%s今年%d' % (name,age))

结果:
XXX今年18

4.字符串相关方法

字符串相关方法的通用格式:字符串.函数()

1.capitalize():将字符串的首字母转换成大写字母,并创建一个新的字符串返回。

str1='abc'
new_str=str1.capitalize()
print(new_str)
print('asv'.capitalize())

结果:
Abc
Asv

2.centre(width,fillchar):将原字符串变成指定的长度并且内容居中,剩下的部分使用指定的字符填充

str1.center(10,'*')
new_str1=str1.center(10,'*')
print(str1,new_str1)

结果:
abc ***abc****

3.rjust(width,fillchar)右对齐

new_str1=str1.rjust(10,'0')
print(new_str1)

结果:
0000000abc

产生学号 py1805009

number=9 #py1805009
# str(数据):将任何其他的数据转换成字符串
num_str=str(number)
print(num_str,type(number))
# 让字符串变成宽度为3,内容右对齐,剩下部分使用'0'填充
new_str=num_str.rjust(3,'0')
print(new_str)

结果:
9 <class 'int'>
009

4.ljust(width,fillchar):左对齐

5.字符串1.join(字符串2):在字符串2中的每个字符串之间插入一个字符串1

new_str='*'.join('bbb')
print(new_str)

结果:
b*b*b

5.if语句

1.

if 条件语句:
条件语句结果为True执行的代码块

执行过程:先判断条件语句是否为True,如果为True就执行if语句后:后面对应的一个缩进的所有的代码。
为False,就不执行冒号后面一个缩进中的代码块,直接执行后续的其他语句。

条件语句:可以是任何有值的表达式,但是一般是布尔值。

if:关键字

  • 练习:用一个变量保存时间(50米短跑),如果时间小于8s,就打印及格
str1='及格'
time=7
if time<8:
    print(str1)  # 只有条件成立的时候才会执行

print(time)  # 不管if语句的条件是否成立,这个语句都会执行

结果:
及格
7

if 条件语句:
语句块1:
else:
语句块2

执行过程:先判断条件语是否为True,如果为True就执行语句块1,否则执行语句块2

练习:用一个变量保存成绩,如果成绩大于60,打印及格,否则打印不及格。

str1='及格'
str2='不及格'
score=59
if score>=60:
    print(str1) 
else:
    print(str2)


结果:
不及格

练习

1.个性化消息:

将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,如“Hello Eric, would you like to learn some Python today?”。

name='吴绍文'
print('hello '+name+', would you like to learn some Python today?')

结果:
hello wushaowen, would you like to learn some Python today?

2.调整名字的大小写:

将一个人名存储到一个变量中,再以小写、大写和首字母大写的方式显示这个人名。

name='wushaowen'
print(name.title())
print(name.upper())
print(name.lower())


结果:
Wushaowen
WUSHAOWEN
wushaowen

3.名言:

找一句你钦佩的名人说的名言,将这个名人的姓名和他的名言打印出来。输出应类似于下面这样(包括引号):Albert Einstein once said, “A person who never made a mistake never tried anything new.”

name='乔布斯'
str1='“你的时间有限,所以不要为别人而活。”'
print(name+'说'+str1)

结果:
乔布斯说“你的时间有限,所以不要为别人而活。”

4.名言2:

重复练习3,但将名人的姓名存储在变量famous_person 中,再创建要显示的消息,并将其存储在变量message 中,然后打印这条消息。

5.剔除人名中的空白:

famous_person='乔布斯'
str1='“你的时间有限,所以不要为别人而活。”'
message=famous_person+'说'+str1
print(message)

结果:
乔布斯说“你的时间有限,所以不要为别人而活。”

存储一个人名,并在其开头和末尾都包含一些空白字符。务必至少使用字符组合"\t" 和"\n" 各一次。 打印这个人名,以显示其开头和末尾的空白。然后,分别使用剔除函数lstrip() 、rstrip() 和strip() 对人名进行处理,并将结果打印出来。

name='\t\t\twushaowen   \n'
print(name.lstrip())
print(name.rstrip())
print(name.strip())

结果:
wushaowen   

           wushaowen
wushaowen

推荐阅读更多精彩内容

  • 一、Java 简介 Java是由Sun Microsystems公司于1995年5月推出的Java面向对象程序设计...
    子非鱼_t_阅读 3,238评论 1 44
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    枫叶appiosg阅读 2,980评论 0 13
  • importUIKit classViewController:UITabBarController{ enumD...
    明哥_Young阅读 1,972评论 1 10
  • 我曾以为,等我穿过山河,一定有我心之所向,只是那个动心的人,一声不吭,去了另一个远方。 一是个孤单的字,它静静地横...
    DrJoseph阅读 144评论 0 0
  • 01 周一的时候,歪姐写了一篇爱焦虑的人都短命吗? | 歪理的推文,不少朋友跟我吐槽。 A说:“真的焦虑,好烦!你...
    歪理心说阅读 173评论 0 4