ASCII、Unicode和UTF-8的关系
在计算机内存中,统一使用Unicode编码,当需要保存到硬盘或者需要传输的时候,就转换为UTF-8编码
记事本编辑的时候,从文件读取的UTF-8字符被转换为Unicode字符到内存里,编辑完成后,保存的时候再把Unicode转换为UTF-8保存到文件:
浏览网页的时候,服务器会把动态生成的Unicode内容转换为UTF-8再传输到浏览器:
-------------------------------------------------------------
字符串格式化:
name=input('请输入你的名字:')
sex=input('请输入你的性别:')
print('欢迎你:'+name) 第一种使用+号连接 建议少用
print('欢迎你:',name) 使用,号连接
print('str1 is ',str1,'str2 is',str2)
print('欢迎你%s'%name) 使用% 占位符 一般使用这个方式
print('欢迎你%s,你的性别是%s'%(name,sex)) 使用占位符%连接
(一)占位符:
%d 代表后面的变量是整数
%f 代表后面跟的是浮点 小数 %.2f保留几位小数 会四舍五入
%s 代表后面跟的是字符串
(二)如果参数少的情况下,使用占位符比较简单 如果参数多的情况下 使用.format()比较简单
age=int(input('请输入你的年龄:'))
grade=float(input('请输入你的成绩:'))
print('你的年龄{yourage},e你的成绩是{yourgrade}'.format(yourage=age,yourgrade=grade))
括号中(qianmian=shuru) 等号前面字段是自己占位时定义的字段,等号后面填的是输入的变量名
.format不能和占位符一起使用 ?不确定
使用.format时 使用了多少位小数就能保存多少位 不会四舍五入
age=int(input('输入你的分数:'))
grade=float(input('输入你的成绩:'))
print('你的成绩年龄是:%s'%age)
print('你的成绩是:%f'%grade)
print('你的年龄是:%s,你的分数是:%.2f'%(age,grade))
print('你的年龄是{you_age},你的成绩是{you_grade}'.format(you_age=age,you_grade=grade))
#总结,fomat不关注数据的类型,但%s需要关注不同的数据类型,用不同的字符来占位 如:%s %0.2f %d等等
# 数据多的时候用format 数据少可以直接用%s
----------------------------------------------------------------
字符串操作
字符串是可以通过下标来进行取值的,但是由于字符串是不可变变量,不能通过下标来修改它的值
username = 'li'
username[0]
打印内存地址
namess1=['aaa','bbb']
namess2=['aaa','bbb']
print(id(namess1))
print(id(namess2))
print(namess1 is namess2)
----------------------------------------------------------
所有字符串的方法,它都不会修改原来字符串的值,都会产生(return 返回)一个新的字符串
但列表能修改值,所以列表的方法一般不会返回值,只会直接修改,导致print 的时候需要先赋值才能打印出东西
必须要会的字符串方法
import string
print(string.ascii_letters+string.digits)#大小写字母+数字
find和index
# print(name.find('n'))#查找字符串的索引 找不到就会返回-1
# print(name.index('n'))#查找字符串的索引 找不到就会直接报错
列表和字符串都有index方法 但是列表没有find方法
format: 格式化字符串
name22='lzc'
age22=22
print('{name},{age}'.format(name=name22, age=age22))#格式化字符串
print('abA123'.isalnum()) # 是否包含数字或字母
print('122'.isdigit()) # 是否是数字
print(name.lower()) # 变成小写
print(name.upper()) # 变成大写
strnames = 'ABCEDF'
join 以指定的连接符拼接可迭代对象 返回字符串
a_list=['q','d','h','a']
print(''.join(a_list)
print('**'.join(a_list) 指定的连接符
结果:
qdha
# join是用来通过某个字符串拼接一个可迭代对象(列表,元组、字典?)的每个元素的 join只能拼接字符串类型的 int类型的是不能拼接的
strip 去掉两边的空格或者指定字符
# print(' mysql '.strip()) # 默认去掉两边的空格和换行
# print('mysqlm '.strip('m'))#当你传入某个字符串的话,它就只会去掉你指定的字符串
# print(' mysql '.lstrip())#默认去掉左边的空格和换行 重要
# print(' mysql '.rstrip())#默认去掉右边的空格和换行 重要
replace # 替换字符串
a='hello world'
b=a.replace('world','python')
print(b)
split 以空格分割字符串,并将分割的list返回 类似与join相反
name1 = 'zcl p y zyz'
# print(name1.split())
# print(name1.split(‘,’))
#切割字符串,返回一个list,按照你指定的字符串去分隔这个字符串,然后放到一个list里面
#如果你什么都不写的话,按照空格分割,多个空格也算一个
---------------------------------------------------------
join和split的区别;
name='lzc,liushneg,liuyang'
print('split:',name.split())
name1=['yubo','hahha','hehhe']
print((',').join(name1))
结果如下:
split: ['lzc,liushneg,liuyang']
yubo,hahha,hehhe
split 是 切割字符串,返回一个列表 字符串变为列表
join 适用于列表变为字符串
--------------------------------------------------------------
其他操作:
# p = str.maketrans('abcdefg','1234567')#前面的字符串和后面的字符串做映射
# print('cc ae gg'.translate(p))#输出按照上面maketrans做映射后的字符串
# #下面是反解
# new_p = str.maketrans('1234567','abcdefg')
# print('cc ae gg'.translate(new_p))
print('1+2+3 1+2+3+4'.splitlines())#按照换行符分割
上面那个可以用print('1+2+3 1+2+3+4'.split(' '))实现 不信 那你试试哈
print('Abcdef'.swapcase())#大小写反转
---------------------------------------------------------------
# 字符串格式化 4种表达方式
# 打印内存地址
#打印指定下标的元素
# 打印数据类型
# 查询列表
#查询字符串中的不存在的字符用两种方法
#查询字符串中的存在的字符用两种方法
#连接一个列表中字符(非数字 )
#拆分字符串中并返回列表
# 检验字符串中是否包含数字或字母
#检验字符串中是否是数字
# 把字符串变成大写
#把字符串变成小写
#去掉两边的空格 去掉左边的空格 去掉右边的空格
#去掉两边指定的字符 z左边的字符 右边的字符
# 替换字符串
# 前面和后面的字段做个映射
# 按照换行符分割
# 大小写反转
# 打印第三第五个字符 打印第二个以后的所有字符 打印除最后一个以外的所有字符
字符串练习题目:
-------------------------------------------------------------------------
# x = "234567ASDsdfghj" #切片和索引
# x = "hello" #显示字符串长度,注意是从1开始
# x = "hello world ASDF" #返回长度为100的字符串,并在左侧填充0
# x = "hello world ASDF" #小写变为大写
# x = "234567ASDsdfghj" #大写变为小写
# x = "234567sdfghj" #判断是否含有至少一个区分大小写的字符,并且这些都是小写
# x = "hello world" #返回标题化字符串
# x = "Hello World" #翻转字符串中的大小写
# x = " hello world " #同时执行lstrip和rstrip,删除两边
# x = "hello world" #检测是否以xx开头或结尾
# x = "234567ASDsd fASDghjASD" #以 行分隔,返回一个包含元素的列表
# x = "234567ASDsdfASDghjASD" #以A分隔x,并可指定次数
# x = "234567ASDsdfASDghjASD" #替换字符串,并且可指定次数
# x = "234567ASDsdfghj" #以7为中间符,分割x
# x = "234567ASDZzsdfghj" #返回x中最大的字母(小写)
# x = "121 234567ASDsdfghj" #截掉x左边的1
# x = "234567sdfghj" #左对齐,并以*填充剩余数量(20)
x = "*" #以x为分隔符重新生成y
# x = "Asdf112321 Gh123J" #判断是否首字符为大写,其它为小写
# x = " " #判断是否只包含空格
# x = "234567f" #判断是否只包含*数字字符*
# x = "234567" #判断是否全为数字
# x = "234567sdfghj" #判断是否全为十进制数字
# x = "234567sdfghj" #判断是否全为字母
# x = "234567sdfghj" #判断是否全为字母或数字
# x = "hello world" #index同find,但查不到,会返回异常!!!
# x = "hello world" #find查找字符串并返回索引值
# x = "name:{2},age:{1},sex:{0}" #format格式化字符串
# x = "hello world" #在指定范围内,返回l的次数
# x = "hello world" #中间插入字符串,两边/填充*
http://www.cnblogs.com/LiChaoAI/p/6959607.html
作业2:
字符串 a = "aAsmr3idd4bgs7Dlsf9eAF"
1.请将 a 字符串的数字取出,并输出成一个新的字符串。
2.请统计 a 字符串出现的每个字母的出现次数(忽略大小写,a 与 A 是同一个字母),
并输出成一个字典。 例 {'a':3,'b':1}
3.请去除 a 字符串多次出现的字母,仅留最先出现的一个,大小写不敏感。例
'aAsmr3idd4bgs7Dlsf9eAF',经过去除后,输出 'asmr3id4bg7lf9e'
4.按 a 字符串中字符出现频率从高到低输出到列表,如果次数相同则按字母顺序排列。
http://blog.csdn.net/youyouheheda/article/details/51212305