数据类型字符编码文件处理
Posted 嗯姆嗯姆嗯姆
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据类型字符编码文件处理相关的知识,希望对你有一定的参考价值。
01数字类型
一、基本使用(int)
1.int用途:年龄、号码、等级···
2.定义方式:age=10 #age=int(10)
x=int(‘1111‘) # int只能将纯数字的字符串转成十进制的整型
print(type(x))
3.常用操作+内置方法
算数运算,比较运算
二、该类型总结
1.存一个值Or存多个值
只能存一个值
2.有序or无序
没有有序无序那么一说
3. 可变or不可变
可变不可变类型总结:
可变指的是改变原值,即在原值基础上进行修改
可变类型的底层原理:在id不变的情况下,值可以改变
不可变类型的底层原理:值改变,id也跟着变
int是 不可变数据类型
age=10
print(id(age))
age=11
print(id(age))
运行的id不同
4.了解(**):
长整型Long,只有在python2中才有长整型号
复数complex
x=1-2j
print(x.real)
print(x.imag)
print(type(x))
一、基本使用(float)
1 用途:薪资 身高 体重
2 定义方式
salary=3.1 #salary=float(3.1)
n=float(‘3.1‘)
3 常用操作
算数运算、比较运算
二、该类型总结
1 存一个值or存多个值
只能存一个值
2 有序or无序
没有有序无序这么一说
3 可变or不可变
float是不可变类型
x=3.1
print(id(x))
x=3.2
print(id(x))
02字符串类型
一、基本使用(str)
1.用途:描述性质数据,比如人名,单个爱好,地址
2.定义方式
name=‘egon‘ #name=str(‘egon‘)
3. 常用操作+内置的方法
优先掌握的操作(*****):
1)按索引取值(正向取+反向取) :只能取
msg[2]=‘A‘
msg=‘hello world‘
print(type(msg[5]))
print(msg[-1])
2)切片(顾头不顾尾,步长)
msg=‘hello world‘
print(msg[1:5],type(msg[1:5]))
print(msg[6:-1])
print(msg[6:11])
print(msg[6:])
print(msg[6::2])
了解(**)
print(msg[0:])
print(msg[::-1])
msg=‘hello world‘
print(msg[-3:-6:-1])
print(msg[6:9:-1])
3)长度len
msg=‘hello world‘
print(len(msg))
4)成员运算in和not in
print(‘SB‘ in ‘my name is alex,alex is SB‘)
print(‘alex‘ in ‘my name is alex,alex is SB‘)
print(‘egon‘ not in ‘my name is alex,alex is SB‘) # 推荐
print(not ‘egon‘ in ‘my name is alex,alex is SB‘)
5)移除空白strip
name=‘ e gon ‘
print(name.strip(‘ ‘))
print(name.strip())
name=‘****A*e*gon****‘
print(name.strip(‘*‘))
name=‘****egon****‘
print(name.lstrip(‘*‘))
print(name.rstrip(‘*‘))
pwd=input(‘>>: ‘).strip() #pwd=‘123 ‘
if pwd == ‘123‘:
print(‘login successful‘)
msg=‘cccabcdefgccccc‘
‘c‘
print(msg.strip(‘c‘))
6)切分split
msg=‘egon:18:male:180:160‘
l=msg.split(‘:‘)
print(l)
print(l[3])
7)循环
msg=‘hello world‘
for x in msg:
print(x)
需要掌握操作
1、strip,lstrip,rstrip
2、lower,upper
name=‘EoN‘
print(name.lower())
name=‘egonN‘
print(name.upper())
3、startswith,endswith
print(‘alex is SB‘.startswith(‘alex‘))
print(‘alex is SB‘.endswith(‘B‘))
4、format的三种玩法
print(‘my name is %s my age is %s‘ %(‘egon‘,18))
print(‘my name is {name} my age is {age}‘.format(age=18,name=‘egon‘)) # 可以打破位置的限制,但仍能指名道姓地为指定的参数传值
print(‘my name is {} my age is {}‘.format(‘egon‘,18))
print(‘my name is {0} my age is {1} {1} {1} {1}‘.format(‘egon‘,18))
5、split,rsplit
info=‘egon:18:male‘
print(info.split(‘:‘,1))
print(info.split(‘:‘,1)) #[‘egon‘,‘18:male‘]
print(info.rsplit(‘:‘,1)) #[‘egon:18‘,‘male‘]
6、join:只能将元素全为字符串的列表拼成一个大的字符串
info=‘egon:18:male‘
l=info.split(‘:‘)
print(l)
new_info=‘-‘.join(l)
print(new_info)
num=[‘a‘,‘b‘,‘c‘]
‘:‘.join(num) #‘a‘+‘:‘+‘b‘+‘:‘+‘c‘
num=[1,2,‘c‘]
‘:‘.join(num) #1+‘:‘+2+‘:‘+‘c‘
7、replace
msg=‘my name is wupeiqi,wupeiqi is SB‘
print(msg.replace(‘wupeiqi‘,‘Pig‘,1))
print(msg)
8、isdigit
print(‘111.1‘.isdigit())
print(‘1111‘.isdigit())
AGE=73
age=input(‘>>: ‘).strip() #age=‘asdfasdf‘
if age.isdigit():
age=int(age)
if age > AGE:
print(‘too big‘)
elif age < AGE:
print(‘too small‘)
else:
print(‘you got it‘)
else:
print(‘必须输入数字啊傻叉‘)
其他操作(了解即可)(**)
1、find,rfind,index,rindex,count
msg=‘my name is alex,alex is hahaha‘
print(msg.find(‘alex‘))
print(msg.find(‘SB‘)) #找不到会返回-1
print(msg.index(‘alex‘))
print(msg.index(‘SB‘)) # 找不到index会报错
print(msg.find(‘alex‘,0,3))
print(msg.count(‘alex‘))
print(msg.count(‘alex‘,0,15))
2、center,ljust,rjust,zfill
print(‘info egon‘.center(50,‘-‘))
print(‘info egon‘.ljust(50,‘-‘))
print(‘info egon‘.rjust(50,‘-‘))
print(‘info egon‘.zfill(50))
3、expandtabs
print(‘a\tb\tc‘.expandtabs(1))
4、captalize,swapcase,title
print(‘my name is egon‘.capitalize())
print(‘my Name Is egon‘.swapcase())
print(‘my name is egon‘.title())
5、is数字系列
num1=b‘4‘ #bytes
num2=u‘4‘ #unicode,python3中无需加u就是unicode
num3=‘壹‘ #中文数字
num4=‘Ⅳ‘ #罗马数字
isdigit():bytes,unicode
print(num1.isdigit())
print(num2.isdigit())
print(num3.isdigit())
print(num4.isdigit())
isdecimal():unicode
print(num2.isdecimal())
print(num3.isdecimal())
print(num4.isdecimal())
isnumberic;unicode,中文,罗马
print(num2.isnumeric())
print(num3.isnumeric())
print(num4.isnumeric())
6、is其他
print(‘abasdf123123‘.isalnum())
print(‘asdfasdf‘.isalpha())
print(‘egon‘.islower())
print(‘ABC‘.isupper())
print(‘ ‘.isspace())
print(‘My Name Is Egon‘.istitle())
二:该类型总结
1 存一个值or存多个值
只能存一个值
2 有序or无序
有序
3 可变or不可变
不可变
name=‘egon‘
print(id(name))
name=‘alex‘
print(id(name))
03.列表类型
作用:多个装备,多个爱好,多门课程,多个女朋友等
定义:[]内可以有多个任意类型的值,逗号分隔
my_girl_friends=[‘alex‘,‘wupeiqi‘,‘yuanhao‘,4,5] #本质my_girl_friends=list([...])
l=list(‘hello‘) # list内只能跟能够被for循环遍历的数据类型
print(l)
l=list({‘a‘:1,‘b‘:2})
print(l)
优先掌握的操作:
1、按索引存取值(正向存取+反向存取):即可存也可以取
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘]
names[0]=‘ALEX‘
print(names)
2、切片(顾头不顾尾,步长)
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘]
print(names[0:3])
3、长度
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘]
print(len(names))
4、成员运算in和not in
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘,4]
print(4 in names)
5、追加
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘]
names.append(‘cxx1‘)
names.append(‘cxx2‘)
names.append(‘cxx3‘)
print(names)
6、删除
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘]
del names[2]
print(names)
7、循环
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘]
for name in names:
print(name)
需要掌握的操作(****)
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘,4,3.1]
names.insert(1,‘SB‘)
print(names)
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘,4,3.1]
res=names.remove(‘wxx‘) # 单纯的删掉,是按照元素的值去删除,没有返回值
print(res)
print(names)
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘,4,3.1]
res=names.pop(1) #拿走一个值,是按照索引去删除,有返回值
print(names)
print(res)
names=[‘alex‘,‘wxx‘,‘lxx‘,‘egon‘,4,3.1]
print(names.pop())
print(names.pop())
names=[‘alex‘,‘wxx‘,‘lxx‘,‘lxx‘,‘egon‘,4,3.1]
print(names.count(‘lxx‘))
print(names.index(‘lxx‘))
names.clear()
print(names)
x=names.copy()
print(x)
names.extend([1,2,3])
print(names)
names.reverse()
print(names)
names=[1,10,-3,11]
names.sort(reverse=True)
print(names)
二:该类型总结
1 存一个值or存多个值
可以存多个值,值都可以是任意数据类型
2 有序or无序
有序
3 可变or不可变
可变
l=[‘a‘,‘b‘]
print(id(l))
l[0]=‘A‘
print(id(l))
以上是关于数据类型字符编码文件处理的主要内容,如果未能解决你的问题,请参考以下文章