2018-07-18课堂笔记整理

一.认识字符串

1.什么是字符串

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

b.引号中单独的符号、数字、字母等叫字符

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

'123'  # 数字字符串
'ahcn'
'^7&#sj'
'中文汉字'
' '
str2 = '\\'
print(str2)
str1 = '床前明月光,\t疑是地上霜。'
print(str1)  

2.阻止转义

可以通过在字符串前面加r或者R,来阻止转义字符转义

str1 = r'\\1\n2'
print(str1)  

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

Unicode编码:使用16位对一个字符进行编码。编码的目的是让字符可以存储到计算机中。(2^16 = 65536 111)
Unicode码中包含了ASSCII码,并且可以表示世界上所有的语言和符号

  • a.获取一个字符的Unicode码
ord1 = ord('曾')
ord2 = ord('超')
ord3 = ord('A')
print(hex(ord1), hex(ord2), ord3)

  • b.将Unicode码转换成字符
  • chr(编码值)
print(chr(0x4eff))

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

print('a' > '曾b')   



二.获取字符串中的字符

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

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

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

count = len('abc\n123')
print(count)
2.通过下标获取字符串中的某一个字符

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

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

str2 = "dy\nup"
print(str2[4])

下标的范围:0 ~ 字符串长度-1; -1 ~ -字符串长度
获取字符的时候,索引值不能操作索引的范围,否则会报IndexError

  • print(str1[3]) IndexError: string index out of range
print(str1[-1])  # 获取字符串str1中的最后的字符
print(str1[-3])  # 获取字符串str1中的倒数第二个字符   
3.获取字符串中的部分字符(切片):

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

a.开始和结束下标都有值:开始下标对应的字符,要在结束下标对应的字符前面(步进是正数)

str3 = 'helol Python'
print(str3[6:12])     # Python
print(str3[-6:12])    # Python

b.开始下标省略:从字符串的最前面取到结束下标前

print(str3[:4])

c.结束下标省略: 从开始位置获取到字符串结束

print(str3[4:])

d.两个都省略: 获取整个字符串的内容

print(str3[:])

e:每两个取一个

print(str3[::2])  # hloPto 

(了解)

print(str3[4:1:-1])  # 3 3-1=2 1 0 
print(str3[::-1])  # 字符串倒序



三。字符串运算符

1. + : 字符串拼接

字符串1+字符串2

str1 = 'hello' +' '+'Python'
print(str1)

注意: + 号两边要么都是数字,要么都是字符串。不能是一个数字一个字符串
print(12+'34')

2. * : 让字符串重复

字符串*整数

str1 = 'abc' * 3
print(str1)

str2 = 'a'*10
print(str2)
3. in

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

result = 'aa' in 'abaaac'
print(result)
4. not in

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

result = '123' not in 'abc'
print(result)
5.格式字符串

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

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

print(str1)

s --> 字符串占位符(格式符)
%d --> 整数占位符(格式符)
%f --> 浮点数占位符
%c --> 长度是1的字符串占位符(字符占位符)---可以给一个字符,也可以给字符的编码值

str2 = '-%s-%d-%f-%c-%c-' % ('我是字符串',123,12.4,'k',97)
print(str2)

%.nf : 使用n值限制小数点后面的小数的位数(默认六位小数)

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

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

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

%x和%X --> 十六进制数据占位符

number = 15
# XXX的十六进制是XXXXX
str4 = '%d的十六进制是0X%x' % (number, number)
print(str4)
6.格式化输出
name = '路飞'
age = 17
# xx今年xx岁
print('%s今年%d岁' % (name, age))
print('%x' % (id(name)))



四.字符串相关方法

1.字符串相关方法的通用格式: 字符串.函数()
str1 = 'abc'
new_str = str1.capitalize()
print(str1, new_str)

2.center(width, fillchar): 将原字符串变成指定的长度并且内容居中,剩下的部分使用指定的字符填充
new_str = str1.center(7, '!')
print(str1, new_str)
3.rjust(width, fillchar): 右对齐
new_str = str1.rjust(7,'*')
print(new_str)


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

new_str = 'py1805'+new_str
print(new_str)
4.ljust(width, fillchar): 左对齐

"123.56" '-120'

5.字符串1.join(字符串2): 在字符串2中的每个字符之间插入一个字符串1
new_str = '123'.join('bbb')
print(new_str)
6.
print(max('abcZ'))




五.if语句

if语句:
结构:

1.

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

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

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

if:关键字

if False:
    print('代码1')
    print('代码2')
    print('代码3')

print('代码4')
  • 练习:用一个变量保存时间(50米短跑),如果时间小于8秒,打印及格
time = 7

if time < 8:
    print('及格')  # 只有条件成立的时候才会执行

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

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

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

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

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



你可能感兴趣的:(2018-07-18课堂笔记整理)