首页 > 编程语言 >python基础:数据类型的内置方法理论、整形(int)的内置方法、浮点型(float)的内置方法、字符串(str)的内置方法、列表(list)的内置方法、可变类型和不可变类型

python基础:数据类型的内置方法理论、整形(int)的内置方法、浮点型(float)的内置方法、字符串(str)的内置方法、列表(list)的内置方法、可变类型和不可变类型

时间:2023-02-04 16:36:05浏览次数:50  
标签:information 内置 int 666 数据类型 字符串 l1 print 方法

目录

一、数据类型的内置方法理论

所谓内置方法就是数据类型内部自带的一些快捷操作

表现形式:

变量名.方法名(参数可以自己加)

变量名或是数据值的后方跟上英文状态的句号然后跟上方法。

注:在尝试记忆的过程中,不推荐死记硬背,建议带入到平时的学习使用中记忆。

二、整形(int)的内置方法

1、类型转换(把其他类型转换成自己的类型)

整形可以把浮点型和特定条件下的变成整形(使用int方法):

1.如果是没有小数部分的浮点型,会直接在使用int方法后变成整形。

a = float(666)
print(type(a))
print(type(int(a)))

img

2.如果是有小数的浮点型,会直接砍掉小数部分,只显示整数部分。

# 这肯定是浮点型的数值,就不打印类型了
b = 666.666
print(type(int(b)))
print(int(b))
# 可以看到小数点后面的全砍掉了

img

3、如果是字符串类型,需要确保组成的字符串中只有数字,如果出现背的字符会直接报错。

# 这里是没有加入其他字符的纯数字字符串
c = '666'
print(int(c))
print(type(int(c)))
# 这里是加入了字母的字符串
d = '666a6'
print(type(int(d)))
print(int(d))
# 通过观察结果发现有字母的会直接报错

img

2、进制转换

1.转换成二进制

a = 10
print(bin(a))  # 0b1010

img

2.转换成八进制

a = 10
print(oct(a))  # 0o12

img

3.转换成十六进制

a = 10
print(hex(a))  # 0xa

img

4.其他进制转换成十进制

# 这里就直接用之前转的数据
b = 0b1010
c = 0o12
d = 0xa
print(int(b))
print(int(c))
print(int(d))

img

特殊情况讲解

我们可以看到上方的转换结果中,其他进制的结果前面都有出现特殊符号,如0b、0o、0x。这是对应进制的代表符号。当我们使用int方法转换其他进制的时候,如果数据是字符串类型,依旧使用进制符号+数值的形式去转换的话会直接失败,这里我们需要在字符串后方跟上进制数才能转换。如果字符串中没有写进制符号也没用影响,在后面跟上进制数一样可以转换。

把值放到字符串中,并且。举例:

# 这里值还是用之前转的数据
x = '1010'
y = '12'
z = 'a'
print(int("0b1100100", 2))
print(int("0o144", 8))
print(int("0x64", 16))
print(int(x, 2))
print(int(y, 8))
print(int(z, 16))

img

三、浮点型(float)的内置方法

1、类型转换(把其他类型转换成自己的类型)

float方法可以把整形、特殊情况下的字符串变成float类型:

a = 11
b = '11.1'
c = '11.1.1'
print(float(a))
print(float(b))
print(float(c))
# 这里的话运行c的转换的时候会直接报错

img

特殊说明:

python对数字的运算其实并不敏感(精确),但是由于背后大佬较多,我们可以使用模块进行精确计算。举例:

# 证明:python对数字不敏感(准确)
print(0.1 + 0.2)  # 经典的0.1+0.2!=0.3
# output:0.30000000000000004
print(1.01 + 1.02)
# output:2.0300000000000002

四、字符串(str)的内置方法

1、类型转换(把其他类型转换成自己的类型)

字符串可以转换所有类型的数据值,从结果看就是在两边加上引号:

a = 11
b = 11.1
c = [1, 1, 2, 2]
d = {'name': 'jason', 'age': 99}
e = {1, 2, 3, 3}
f = (1,3,3,4)
g = True
print(str(a))
print(type(str(a)))
print(str(b))
print(type(str(b)))
print(str(c))
print(type(str(c)))
print(str(d))
print(type(str(d)))
print(str(e))
print(type(str(e)))
print(str(f))
print(type(str(f)))
print(str(g))
print(type(str(g)))

2、内置方法(掌握)

1.索引取值

根据字符所在位置取值(从0开始)

# 索引取值
information = 'hello jason'
print(information[0])

这里就是取了第一个值:

img

切片取值
# 升级版本:切片取值
information = 'hello 你好今天又是开心的一天'
print(information[6:])  # 从6取到结尾
print(information[:6])  # 取到第六个就结束,第六个不取
print(information[:])  # 取所有的值
print(information[-1:])  # 从后往前取,从后往前取的时候
print(information[-5:-1])  # 用负的位置坐标取值,需要小的在前大的在后
print(information[6:10])  # 从第六个开始,取到10,但是取不到10的位置,只能到九
print(information[6:10:2])  # 从第六个开始,取到10,但是取不到10的位置,并且两个字符取一次
print(information[10:6:-1])  # 从第10个开始,取到6,但是取不到6的位置,是从后往前取

2.统计字符串长度(个数)

len:计算字符串长度或个数

# 计算长度的len
information = 'hello 你好明天星期天'
print(len(information))

img

注:字符串中的空格也算一个字符。

3.strip方法:删除首尾的内容

作用介绍:删除字符串首尾的空格,或是指定的字符。生活中主要使用在账号密码的输入中,可以减少错误。

# 删除字符串首尾的空格
# information = '  hello 你好明天星期天  '
# print(information.strip())
# 删除字符串首尾的指定字符
information = '  hello  你好明天星期天 '
print(information.strip('好'))
# 这里可以看到没有变化,因为'你好在中间位置'

information = '  hello 你好明天星期天天天天'
print(information.strip('天'))
# 这里可以看到后面的天字没了
两种变形:

lstrip和rstrip:删除左侧或右侧字符的strip方法

# 左侧:lstrip
information = '  hello 你好明天星期天  '
print(len(information))
print(information.lstrip())
print(len(information.lstrip()))
# 右侧:rstrip
information = '  hello 你好明天星期天  '
print(information.rstrip())
print(len(information.rstrip()))

4.split方法:切块

split:删除指定的字符并从删除的位置把字符串变成列表中的一个个值

# split
information = 'hello 你好明天星期天'
print(information.split(' '))
# 这里我们可以看到根据中间的空格把字符串分成了含有两个值的列表,并且空格被删掉了
# 分成指定个数个块
information = 'hello 你好明天 星期天'
print(information.split(' '))
print(information.split(' ',maxsplit=1))

这里表现出我们可以通过设置参数,设定切割次数:

rsplit:从右边切割

这里我们可以发现,split只有从右边切割的方法,没有从左边切割的方法,因为split本身就是从左往右切割的。

# 其他形式:
# 从右边切割
information = 'hello 你好明天 星期天'
print(information.rsplit(' ',maxsplit=1))
# 这里只切割一次,方便比较

5.format方法:格式化输出

format方法拥有和%s相似的功能,但是更为强大,也更方便

format方法有四种表现形式,如下:

表现形式一

插入占位的符号,输入占位符输入的值,不能多不能少

# 表现形式一
information = 'hello 你好明天星期天,{},{},{}'
print(information.format('pig','pig','pig'))

表现形式二

通过插入数据的索引位置,把相应的值插入占位符中

# 表现形式二
information = 'hello 你好明天星期天,{0},{0},{1}'
print(information.format('big','pig'))

表现形式三

通过变量的绑定关系插入数据值格式化输出

# 表现形式三
information = 'hello 你好明天星期天,{first},{first},{second}'
print(information.format(first='big',second='pig'))

表现形式四

通过在定义想要输出的文本时,在文本前面加上f就可以使用format方法格式化输出

# 表现形式四
name = input('username>>>:')
age = input('age>>>:')
information = f'hello 你好明天星期天{name},age is {age}'
print(information)

3、内置方法(了解)

1.大小写的改变和判断

upper()、lower()、isupper()、islower()可以分别用来改变字符串中字母的大小写或是判断是不是全是大写或小写(其他字符不受影响)。这些功能通常会出现在登陆环节中的验证码中,降低验证的失误率。

upper()

把当前字符串中的字母全部转变成大写的形式

# 1、字母大小写变换和判断
# upper()把所有字母变成大写
infor = 'hello world'
print(infor.upper())

img

lower()

把当前字符串中的字母全部转变成小写的形式

# lower()把所有字母变成小写
infor1 = 'HELLO WORLD'
print(infor1.lower())

img

isupper()

判断当前字符串中的字母是否全为大写的形式,如果是返回True,否则返回False

# isupper()判断当前字符串中的字母是否全为大写的形式
infor2 = 'Hello World'
infor1 = 'HELLO WORLD'
print(infor1.isupper())
print(infor2.isupper())

这里我们用两组字符串进行对比可以明显看到差别:
img

islower()

判断当前字符串中的字母是否全为小写的形式,如果是返回True,否则返回False

# islower()判断当前字符串中的字母是否全为小写的形式
infor2 = 'Hello World'
infor = 'hello world'
print(infor.islower())
print(infor2.islower())

这里我们也用两组字符串进行对比:
img

2.判断字符串中的数据值是否是纯数字:isdigit

这里我们使用isdigit进行判断,如果字符串中是纯数字就会返回True,否则返回False

# 2、判断字符串中的数据值是否为纯数字,是就返回True,否则返回False
test_1 = '11111'
test_2 = '不太聪明的狗子康11111'
print(test_1.isdigit())
print(test_2.isdigit())

结果如下:
img

3.替换字符串中的指定内容:replace

根据输入的内容,从左往右依次替换其中的需要被替换的内容

1.替换选中内容的所有对象

# 3.替换指定内容:replace
test_2 = '不太聪明的狗子康11111'
print(test_2.replace('1','喜欢干坏事'))

结果如下:
img

2.替换选中内容,并且可以自定义替换个数

# 替换指定内容并且指定替换的个数
test_2 = '不太聪明的狗子康11111'
print(test_2.replace('1','喜欢干坏事',3))

结果如下:
img

4.字符串的拼接:join

通过之前的学习,我们可以察觉到数据值之间可以通过运算符号进行操作,比如可以通过'+'号连接起来。也可以通过'*'号一次性输出多个数据值。

除去这些方法,还有'join'方法可以打到同样的效果,并且更加高效,更加方便。

代码展示:

通过运算符号操作

# 通过运算符号进行操作
recent = '你好明天'
recent1 = '星期天'
print(recent + recent1)
print(recent * 10)

通过join方法进行拼接

# 通过join方法:字符串的拼接
recent = '你好明天'
recent1 = '星期天'
print('|'.join([recent1,recent]))
# 通过'|'符号把列表中的两个数据值组成一个字符串

这里的话需要把字符串放入列表中输出,否则会因为不能装下这么多数据值而报错

5.统计指定字符出现的次数:count

count这个单词就是统计的意思,所以它的作用也是一样的,可以统计指定字符出现的次数

# 统计指定字符出现的次数
recent2 = '你好明天星期天,96969696'
print(recent2.count('9'))
# 这里统计的是9出现的次数
print(recent2.count('96'))
# 这里统计的是96出现的次数

6.判断字符串的开头或结尾

在字符串中我们可以startswith和endswith来判断字符串开头或结尾是否是我们想要的数据值。

startswith

判断开始位置的值

# startswith:判断字符串开始的值
recent1 = '你好明天星期天'
print(recent1.startswith('你'))
print(recent1.startswith('你好'))
print(recent1.startswith('你好明天'))
# 取一个中间的字符用于举反例
print(recent1.startswith('星'))

endswith

判断结束位置的值

# endswith:判断字符串末尾的值
recent1 = '你好明天星期天'
print(recent1.startswith('你'))
print(recent1.startswith('你好'))
print(recent1.startswith('你好明天'))
# 取一个中间的字符用于举反例
print(recent1.startswith('星'))

7.其他方法补充

①:title

起到一个把所有英文单词首字母大写其他字母小写的作用

res = 'helLO wORld hELlo worLD'
print(res.title())  # Hello World Hello World
②:capitalize

起到一个把第一个单词首字母大写,其他字母小写的作用

res = 'helLO wORld hELlo worLD'
print(res.capitalize())  # Hello world hello world
③:swapcase

起到把所有字母的大小写反转的作用

res = 'helLO wORld hELlo worLD'
print(res.swapcase())  # HELlo WorLD HelLO WORld
④:index

返回指定字符的索引值,如果找不到字符会直接报错。当输入多个字符的时候会返回字符中第一个字符的索引值。

res = 'helLO wORld hELlo worLD'
print(res.index('O'))
# 这里是找不到的情况
print(res.index('c'))  # 找不到直接报错
⑤:find

也是用于寻找字符的索引值,如果找不到字符就返回值'-1'。当输入多个字符的时候会返回字符中第一个字符的索引值。

res = 'helLO wORld hELlo worLD'
print(res.find('O'))
print(res.find('c'))  # 找不到默认返回-1
print(res.find('LO'))  # 3

五、列表(list)的内置方法

1、类型转换(把其他类型转换成自己的类型)

注:能够被for循环遍历的数据类型都可以转换成列表

print(list('hello'))
print(list({'name': 'jason', 'pwd': 123}))
print(list((1, 2, 3, 4)))
print(list({1, 2, 3, 4, 5}))
print(list({'name': 'java','age':'18'}))

运行结果如下:

img

2、索引取值

根据列表的索引顺序,可以取出指定位置的数据值

l1 = [111, 222, 333, 444, 555, 666, 777, 888]
print(l1[0])
# 取第一个
print(l1[-1])
# 取最后一个

img

切片操作

类似字符串的切片,可以参考字符串的例子。不过操作单位是一个个的数据值不再是一个个字符。

l1 = [111, 222, 333, 444, 555, 666, 777, 888]
print(l1[0:5])
# 从头取到第五个,第五个取不到
print(l1[:])
# 取所有的数据
print(l1[::-1])
# 从数据的后面往前取

img

3、统计列表的长度(个数)

依旧是len方法,不过跟字符串不同的是,列表中一个数据值算一个长度。

print(len(l1))  # 8

4、数据值的修改

这里跟之前说的一样,通过索引位置修改绑定的值。

l1 = [111, 222, 333, 444, 555, 666, 777, 888]
l1[0] = 123
print(l1)
# 开头就变成了123

5、添加数据值

方式一:尾部添加数据值——append

# 方式一:尾部添加数据值——append
l1 = [111, 222, 333, 444, 555, 666, 777, 888]
l1.append('你好明天星期天')
print(l1)

方式二:任意位置插入数据值——insert

# 方式二:任意位置插入数据值——insert
l1 = [111, 222, 333, 444, 555, 666, 777, 888]

l1.insert(-1,'你好明天星期天')
print(l1)
# 这里我们发现反方向插入数据的时候,不能把数据值加入到最后,只能加在倒数第二个位置
l1.insert(3,'你好明天星期天')
print(l1)
# 这里顺序插入数据没什么特点

方式三:扩展列表(合并列表)——extend

# 方式三:扩展列表(合并列表)——extend
l1 = [111, 222, 333, 444, 555, 666, 777, 888]
l2 = ['你好明天星期天','6666']
l1.extend(l2)
print(l1)
# 可以从结果发现加进去的列表会在后面

6、删除列表数据

方式一:通用的删除关键字——del

# 方式一:通用的删除关键字——del
l1 = [111, 222, 333, 444, 555, 666, 777, 888]
del l1[1]
# 删除索引1位置的数据值
print(l1)

img

方式二:删除指定数据值——remove

# 方式二:删除指定数据值——remove
l1 = [111, 666, 333, 444, 555, 666, 666, 666]
l1.remove(666)
print(l1)
# 这里我们可以发现remove方法一次只能删除一个数据值,并且是从前往后删

img

方式三:删除指定索引处的值或是删除最后的数据值——pop(删除的同时可以取得数据值)

# 方式三:删除指定索引处的值或是删除最后的数据值——pop(删除的同时可以取得数据值)
# 删除最后的数据并获得它
l1 = [111, 222, 333, 444, 555, 666, 777, 888]
res = l1.pop()
print(res, l1)

# 删除指定的数据并获得它
res = l1.pop(4)
# 这里是删除索引为4的数据值——555
print(res, l1)

img

7、排序

方式一:升序——sort

# 方式一:升序——sort
l1 = [111, 444, 555, 666, 222, 333, 777, 888]
l1.sort()
print(l1)

img

方式二:降序——sort(reverse=True)

# 方式二:降序——sort(reverse=True)

l1 = [111, 444, 555, 666, 222, 333, 777, 888]
l1.sort(reverse=True)
print(l1)

img

8、统计某个数据值出现的次数——count

### 8、统计某个数据值出现的次数——count
l1 = [111, 222, 333, 444, 555, 666, 666, 666, 666]

print(l1.count(666))

img

9、颠倒列表的排序——reverse

### 9、颠倒列表的排序——reverse

l1 = [111, 222, 333, 444, 555, 666, 777, 888]
l1.reverse()
print(l1)

img

六、可变类型和不可变类型

当我们在验证字符串和列表的相关功能的同时,我们会发现两者的输出方式不一样,使用方法后列表只需要输出列表就可以得到改变等候的结果,但是字符串需要把方法放大打印的语句中才能输出改变后的结果。这里我们引进了可变类型和不可变类型来解释其中原理。当字符串应用了内置方法后,在内存中它的绑定的内存地址并没有改变(就是没有修改自己的值),而是产生了一个新的值,我们输出的也是这个值。到了列表中,就相当于直接修改了列表中的数据,我们如果用变量名绑定方法执行的语句,打印出来后会得到一个'None',而直接打印列表就可以得到改变后的结果,但是列表的内存地址并没有改变只是其中的数据换了。

规律小结:

可变类型:值改变 内存地址不变

不可变类型:值改变 内存地址肯定变

标签:information,内置,int,666,数据类型,字符串,l1,print,方法
From: https://www.cnblogs.com/wxlxl/p/17091827.html

相关文章