Day3-Python-Python字符串&if语句学习-2018/7/18


1.什么是字符串

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

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

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

转义字符

'123' 数字字符串
'ancn'
'^7&#sj'
'中文汉字'
' ' 空格

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

ouput:`,床前明月光,\n疑是地上霜。

2.阻止转义

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

str1 = r'\\'
print(str1)
str2 = '\\\\'
print(str2)
str3 = '\\1\n2'
print(str3)
str4 = r'\\1\n2'
print(str4)

output:\\,\\,\1\n2,\\1\n2

3.python中字符串中的字符是Unicode编码(C语言,ASCII码)

Unicode编码:使用16位对一个字符进行编码,编码的目的是让字符可以存储到计算机中。最大整数65536

Unicode码中包含了ASCII码,可以表示世界上所有的语言和符号

a.获取一个字符的Unicode码

ord('字符')

ord1 = ord('张')
ord2 = ord('书')
ord3 = ord('语')
print(hex(ord1))
print(hex(ord2),hex(ord3))

print(ord('张'),ord('书'),ord('语'))
print(hex(ord('张')),hex(ord('书')),hex(ord('语')))

output:0x5f20
0x4e66 0x8bed
24352 20070 35821
0x5f20 0x4e66 0x8bed

b.将Unicode码转换成字符

chr(编码值)

print(chr(0x4eff))
print(chr(0x5f20))

output:仿

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

比较字符大小的时候,实质比的是它们的编码的大小。

print('abc'>'b')
print('Z'>'a','z'>'a')
print('a'>'ab')
print('Z'>'z')
print('ac'>'ab')
print('a'>'张')

output:False
False,True
False
False
True
False



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

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

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

count1 = len('abc123');count2 = len('abc\n123')
print(count1,count2)
print(len('abc123'),len('abc\n123'))

output:6,7
6,7

2.通过下标获取字符串中的某一个字符(索引值=长度-1)

字符串中每个字符都对应一个下标(索引),我们可以通过索引值去获取固定的某个字符:print(字符串[索引值])

'abc' --> a->0,b->1,c->2

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


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

output:a,c,p

下标的范围:0 ~ 字符串长度-1;-1 ~ -字符串长度

获取字符的时候,索引值不能超过索引的范围,否则会报错IndexError

str1 = 'abc'
print(str1[2])

output:c

print(str1[3]) # IndexError: string index out of range

print(str1[-1])

output:c

获取字符串str1中的最后的字符

print(str1[-2])

output:b

获取字符串str1中的倒数第二个字符

3.获取字符串中的部分字符(切片):(通过字符获取下标?)

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

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

str3 = 'hello Pyth on'
#       01234567891011  
print(str3[6:12])
print(str3[-6:12])
print(str3[11])

output:Python,Python,n

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

print(str3[:4])

output:hell

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

print(str3[4:])

output:o Python

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

print(str3[:])

output:hello Python

f.

print(str3[::2]) # 0-10: 0 0+2 2+2 4+2 6+2 8+2

output:hloPto

(了解)当步进是负数的时候,即从右往左取

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

output:lleo,
ll,
nohtyP olleh,

lleh,
nohtyp o,从最要边往[3]取
nohtyP o,



1. +:字符串拼接

字符串1 + 字符串2

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

output:hello Python

注意:+号两边要么都是数字,要么都是字符串。不能是一个数字,一个字符串。

print(12+'34') 报错:TypeError: unsupported operand type(s) for +: 'int' and 'str'

2.*:让字符串重复

字符串 * 整数

str1 = 'abc' * 3
print(str1)

output:abcabcabc

3.in

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

result = 'a' in 'abc'
print(result)

output:True

4.not in

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

result = '123' not in 'abc'
print(result)

output:True

5.格式字符串

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

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

output:abc>>>123, abc>>>12!!!3

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

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

output:-我是字符串-123-12.400000-k,-我是字符串-123-12.4-k-a

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

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

output:金额:100.00元

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

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

output:金额:%.2f元

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

number = 15

XXX的十六进制是XXXXX

str4 = '%d的十六进制是0X%x' % (number,number)
print(str4)

output:15的十六进制是0Xf

6.格式化输出

name = 'QQ'
age = 18

xx今年xx岁

print('%s今年%d岁' % (name,age))
print('%dAAA' % (2))
number = 10
str4 = '%d的八进制是%o' % (number,number)
print(str4)
nub=10
print('%d的八进制是%o' % (nub,nub))

output:QQ今年18岁,2AAA,10的八进制是12,10的八进制是12



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

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

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

output:abc,Abc,Abc——————这里的str1没变,生成了一个新的new_str=str.capitalize=Abc

2.center(width,fillchar):将原字符串变成指定的长度并且内容居中,且fillchar为填充的字符。

new_str = str1.center(7,'*')
print(str1,new_str)

output:abc,** abc **

3.rjust(width,fillchar):同上,右对齐

new_str = str1.rjust(7,'*')
print(new_str)

output:****abc

产生学号

number = 19 #py1805009

str(数据):将任何其他的数据转换成字符串

num_str = str(number)
print(num_str,type(num_str))

output:19,<class 'str'>

让字符串变成宽度为3,内容右对齐,剩下部分使用'0'填充

new_str = num_str.rjust(3,'0')
print(new_str)

new_str = 'py1805'+new_str
print(new_str)

output:019,py1805019

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

number = 18
num_str = str(number)
print(num_str,type(num_str))
new_str = num_str.ljust(9,'0')
print(new_str)

output:18,<class 'str'>,180000000

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

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

output:baaaabaaaab

# 6.maketrans()
print(str.maketrans('aaa','bbb'))
print(max("abc"))

output:{97: 98},c

1 |capitalize()|将字符串的第一个字符转换为大写
2| center(width, fillchar)|返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。
3| count(str, beg= 0,end=len(string))|返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数
4| bytes.decode(encoding="utf-8", errors="strict")|Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。
5| encode(encoding='UTF-8',errors='strict')|以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'
6| endswith(suffix, beg=0, end=len(string))|检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
7| expandtabs(tabsize=8)|把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。
8| find(str, beg=0 end=len(string))|检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1
9| index(str, beg=0, end=len(string))|跟find()方法一样,只不过如果str不在字符串中会报一个异常.
10| isalnum()|如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False
11| isalpha()|如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False
12 |isdigit()|如果字符串只包含数字则返回 True 否则返回 False..
13 |islower()|如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
14 |isnumeric()|如果字符串中只包含数字字符,则返回 True,否则返回 False(中文数字也可以)
15 |isspace()|如果字符串中只包含空白,则返回 True,否则返回 False.
16| istitle()|如果字符串是标题化的(见 title())则返回 True,否则返回 False
17|isupper()|如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
18| join(seq)|以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
19| len(string)|返回字符串长度
20| ljust(width[, fillchar])|返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。
21 |lower()|转换字符串中所有大写字符为小写.
22 |lstrip()|截掉字符串左边的空格或指定字符。
23| maketrans()|创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
24 |max(str)|返回字符串 str 中最大的字母。
25| min(str)|返回字符串 str 中最小的字母。
26 |replace(old, new [, max])|把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。
27 |rfind(str, beg=0,end=len(string))|类似于 find()函数,不过是从右边开始查找.
28 |rindex( str, beg=0, end=len(string))|类似于 index(),不过是从右边开始.
29| rjust(width,[, fillchar])|返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串
30 |rstrip()|删除字符串字符串末尾的空格.
31 |split(str="", num=string.count(str))|num=string.count(str)) 以 str 为分隔符截取字符串,如果 num 有指定值,则仅截取 num 个子字符串
32 |splitlines([keepends])|按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
33 |startswith(str, beg=0,end=len(string))|检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。
34 |strip([chars])|在字符串上执行 lstrip()和 rstrip()
35 |swapcase()|将字符串中大写转换为小写,小写转换为大写
36 |title()|返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())
37 |translate(table, deletechars="")|根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中
38 |upper()|转换字符串中的小写字母为大写
39 |zfill (width)|返回长度为 width 的字符串,原字符串右对齐,前面填充0
40 |isdecimal()|检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。



if语句

结构:

1.

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

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

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

if:关键字

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

print('代码4') #不属于if语句中的代码块

output:代码4

练习:用一个变量保存时间(50米短跑时间),如果时间小于8s,就打印及格

time = 7

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

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

output:7

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

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

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

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

output:及格

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容