python-day8-日志-2019-07-31

day8-字符串

一.字符串

1.什么是字符串(str)

(1)字符串
字符串是容器型数据类型(序列),以单引号或者双引号作为容器的标志。引号中所有的内容都属于字符串元素
'abc' - > 元素分别是'a','b','c''
'a,b,c' - > 元素分别是'a',',','b',',','c',5个元素
特点:不可变,有序(支持下标操作)
python中三个单引号或者双引号引起来的也是字符串,这种字符串可以在字符串内部直接回车换行

str1 = '''sas
sdff
'''

(2)字符串中的元素
字符串中元素又叫字符(注意:python中有字符的概念,但是没有字符类型,长度是1的字符串就可以看成字符)
a.普通字符:字母,数字,各国的文字和符号等(可以直接写在引号中的符号)
‘abc’,'odjfo',
b.转义字符:字符串中在一些特定的符号前加入\来表示特殊功能和意义
'表示一个单引号,"表示一个双引号
\n表示换行 \表示字符串中间有一个
\t 相等于tab键
c.编码字符:\u 4位16进制 -将四位16进制数对应的编码值转化成字符
1)字符编码
计算机只有直接存储数字的能力,不能直接存储字符;当需要用计算机存储字符时候,实质存的是字符对应的固定的数字,这个数字就是字符在计算机之中的编码
每一个字符和数字的对应关系叫编码表
2)ASCII码表和Unicode编码表
Unicode编码表是ASCII的扩展。ASCII码表是由美国国家标准制定的专门针对美国符号进行编码的,里面只包含一些特殊符号,字母和数字(不包含中文,日语,韩语 等)
python采用的是Unicode编码表。包含了世界上所有国家所有语言的符号(又叫万国码)
中文范围 4E00-9FA5:CJK 统一表意符号 (CJK Unified Ideographs)
3)字符编码相关的方法
chr(编码值) - 将编码转换为对应的字符
ord(字符) - 获取字符对应的编码值

# 1.字符串中的内容
str1 = 'abc\'12\"3'
# str1 = "ab"c'123"
print(str1)

str2 = 'abc\n123'
print(str2)

str3 = '\tabc\\n123'
str4 = '    abc\\n123'
print(str3, len(str3), len(str4))

str5 = "hh\u5e00abc"
print(str5)

str6 = 'abc 123'
str7 = 'abc123'
str8 = '1'
num = 1

# 2.字符编码
print(chr(97), chr(65))
print(chr(0x1800))
for x in range(0x1800, 0x18af):
    print(chr(x), end=' ')
print()

for x in range(0x1100, 0x11ff):
    print(chr(x), end=' ')
print()

num = 0
for x in range(0x4e00, 0x9fa5):
    num += 1
    print(chr(x), end=' ')
    if num % 35 == 0:
        print()
print()

# ord()
print(ord('余'), ord('婷'))
print(hex(ord('余')), hex(ord('婷')))

name1 = '余婷'
name2 = '\u4f59\u5a77'
print(name1, name2)

print('z' > 'a')    # True
print('Z' > 'a')    # False

二.字符串操作

1.获取字符

和列表获取元素一样
(1)获取单个字符
str1 = 'hello world'
(2)字符串切片
字符串[开始下标:结束下标:步长]
(3)遍历
for char in 字符串:
'A' <= char <= 'Z' -> 判断是不是大写字母
'A' <= char <= 'Z' or 'a' <= char <= 'z' -> 判断是不是字母
'\u4e00' <= char <= '\u9fa5' -> 判断是不是中文

print('hello world!'[2])
print('hello world!'[-2])
print('hello world!'[2:6:2])
print('hello world!'[2:6:-2])  # 为空,''
print('hello world!'[3:])
print('hello world!'[3::-1])
for char in 'acsa00':
    print(char)
# 算出下面那句话有多少小写字母。方法1
count = 0
str3 = 'How Are You! Im Fine, THANK YOU!'
for char in str3:
    if 122 >= ord(char) >= 97:
        count += 1
print(count)
# 方法2
count = 0
str2 = 'How Are You! Im Fine, THANK YOU!'
for char in str2:
    if 'a' <= char <= 'z':
        count += 1
print(count)

2.字符串操作

(1)+ 和 *
字符串1 + 字符串2 -> 将字符串1和字符串2拼接在一起产生一个新的字符串
字符串 * N / N * 字符串 -> 字符串重复N次产生一个新的字符串

str1 = 'abc'
str2 = '123'
print(str1 + str2)  #'abc123'
print(str1 * 3)     # 'abcabcabc'

(2) == , !=

print('abc' == 'acd')  # True
print('abc' == 'abc')  # False

(3)>, < , >=, <=
只能两个字符串比较大小 - 从前往后找到第一组不相等的字符,比较他们编码值的大小,谁的编码值大,谁就大

print('abc' > 'bc')   # False
print('abcd' > 'abca')  # True

(4)in / not in
字符串1 in 字符串2 -> 判断字符串2中是否包含字符串1(判断字符串1是否是字符串2的字串)

str3 = 'how are you!'
print('how' in str3)   # True
print('h' in str3)  # True
print('ha' in str3)  # False

(5) len, max, min, sorted, str
字符串中只有数字序列才能求和 sum(字符串)
字符串转换:所有的数据都可以转换成字符串,转换的时候是将数据放在引号中

str3 = 'how are you!'
print(len(str3))
str3 = '\\how are \tyou!'
print(len(str3))
str3 = '\u4effhow are \tyou!'
print(len(str3))

(6)r语法
在字符串的最前面加r或者R,可以阻止字符串中所有的转义字符转义

str1 = '\tho \nare \'you\u4e00'
print(str1)
str1 = r'\tho \nare \'you\u4e00'
print(str1)

(7)格式字符串
在字符串中用格式占位符表示字符串中不确定的部分
a.语法:包含格式占位符的字符 % (数据1, 数据2.。。。。) -()中数据的个数和类型要和前面格式占位符一一对应
b.格式占位符
%s -- 字符串
%d -- 整数
%.Nf -- 浮点数,N控制小数点后小数的位数(还可以M.N)
%c - 字符 (可以将数字转换成字符)
注意:
1)所有的数据都可以使用%s作为个数占位符
2)所有的数据都可以使用%s来接收

# name = input('请输入姓名:')
# age = int(input('请输入年龄:'))
# gender = input('请输入性别:')
# # xx今年xx岁,性别:X!
# message = name+'今年'+str(age)+'岁,性别:' + gender + '!'
# message2 = '%s今年%d岁,性别:%s!' % (name, age, gender)
# print(message)
# print(message2)
str4 = 'a: %s, b:%d, c:%f, d:%.2f e:%c' % ('HOW', 100, 1.23456, 1.23456, 'A')
print(str4)
str4 = 'a: %s, b:%d, c:%f, d:%.2f e:%c' % ('HOW', 100, 1.23456, 1.23456, 97)
print(str4)
str4 = 'a: %s, b:%s, c:%s, d:%s e:%s' % ('HOW', 100, 1.23456, 1.23456, 97)
print(str4)

3.字符串相关方法

1.对齐方式

字符串.center(宽度, 填充字符=' ') - 居中
字符串.ljust(宽度, 填充字符=' ') - 左对齐
字符串.rjust(宽度, 填充字符=' ') - 右对齐
字符串.zfill(宽度) == 字符串.gjust(宽度, 0)

str1 = 'abc'
print(str1.center(9, '+'))    # +++abc+++, 居中
print(str1.ljust(9, '+'))     # abc++++++, 左对齐
print(str1.rjust(9, '+'))     # ++++++abc, 右对齐
print(str1.zfill(9))          # 000000abc
# 001, 002, 003, ..., 010, 100
num = 12    # 012
# num = 9     # 009
print(str(num).zfill(3))

2.统计子串的个数

# 字符串1.count(字符串2)  - 统计字符串1中字符串2出现的次数
str1 = 'how are you! Im fine, thank you! and you?'
print(str1.count('you'))    # 3
print(str1.count('h'))     # 2
print(str1.count('you', 0, 12))  # 在下标是[0, 12)范围内统计'you'的个数

3.获取子串下标

print(str1.find('you'))   # 8
print(str1.index('you'))  # 8
print(str1.find('you1'))   # -1
# print(str1.index('you1'))  # ValueError: substring not found

4.join方法

字符串.join(序列) - 将序列中的元素用字符串连接产生一个新的字符串

# 要求序列中的元素必须是字符串, 如果是字典key是字符串
new_str1 = '+'.join('123')
print(new_str1)   # '1+2+3'
new_str1 = 'and'.join(['小明', '小花', '小红'])
print(new_str1)   # 小明and小花and小红
new_str1 = '-'.join({'name': '小明', 'age': 18,'gender': 'boy'})
print(new_str1)   # name-age-gender
# new_str1 = '+'.join([1, 2, 3])   # TypeError: sequence item 0: expected str instance, int found
# print(new_str1)

5.替换

字符串1.replace(字符串2, 字符串3) - 将字符串1中所有的字符串2都替换成字符串3
字符串1.replace(字符串2, 字符串3, N) - 将字符串1中前N个字符串2替换成字符串3

str1 = 'how are you! Im fine, thank you! and you?'
new_str1 = str1.replace('you', 'YOU')  # how are YOU! Im fine, thank YOU! and YOU?
print(new_str1)
new_str1 = str1.replace('you', 'me', 2)  # how are me! Im fine, thank me! and you?
print(new_str1)

6.字符串切割

字符串1.split(字符串2) - 将字符串2作为切割点切割字符串1, 返回一个列表

str1 = 'how are you! Im fine, thank you! and you?'
str_list = str1.split(' ')
print(str_list)   # ['how', 'are', 'you!', 'Im', 'fine,', 'thank', 'you!', 'and', 'you?']
str_list = str1.split('!')
print(str_list)  # ['how are you', ' Im fine, thank you', ' and you?']

7.字符串常用方法

name = "ada, lovelace"
print(name.title())  # 把字符串里面的单词首个字母大写
print(name.upper())  # 把字符串里面的单词每个字母都大写
print(name.lower())  # 把字符串里面的单词每个字母都小写
print(name.replace("ada", "hello"))  # 把字符串"ada"替换为"hello"
print(name.find("ada"))  # 找出字符串"ada"在整个字符串中的首个位置下标
a = "    python   "
print(len(a))
print(len(a.rstrip()))  # rstrip能够删除字符串末尾多余的空白
print(len(a.lstrip()))  # rstrip能够删除字符串末尾多余的空白
print(len(a.strip()))  # rstrip能够同时删除字符串开头和末尾多余的空白
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、字符串基础 1. 什么是字符串(str) 1)字符串 字符串是容器型数据类型(序列) 以单引号或者双引号作为容...
    Lis_reak阅读 328评论 0 0
  • 字符串 review 1.字典(dict) {key:value, key1:value1,...}特点: 可变的...
    漫磋嗟阅读 326评论 0 0
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,402评论 0 2
  • 1.什么是字符串(str) 1)字符串是容器型数据类型(序列),以单引号和双引号作为容器标志,引号中的所有内容都是...
    HuangXiongjin阅读 256评论 0 0
  • 文 | 等风来的fox 01 读书时期,相信每个人都有共同的经历,那就是父母苦口婆心的对你说,你要和学习成绩好的同...
    等风来的fox阅读 910评论 0 2