Python基本数据类型

一、整形 int

1.1 -int #将字符串转化为数字类型

age = '20'
print(type(age))
num = int(age)
print(num)
print(type(num))

<class 'str'>
20
<class 'int'>

1.2 -bit_length() #当前数字的二进制是几位表示

num = age.bit_length()
print(num)
5
a = 1
print(a.bit_length())
1
b = 3
print(b.bit_length())
2

二、字符串 str

2.1
-capitalize() #将字符串首字母转化为大写
-title #转化为标题(所有首字母改为大写)

name = 'wangxiaolong'
print(name.capitalize())
Wangxiaolong

a = 'wang xiao long'
print(a.title())
Wang Xiao Long

2.2
-casefold() #将字符串中的大写转换为小写,更加厉害,可以转换全部
-lower() #将字符串中的大写转换为小写,只能转化英文

name = 'WANGxiaoLONG'
print(name.casefold())

wangxiaolong

2.3
-center() #设置宽度为为N并居中,空白填充
-ljust() #右边填充
-rjust()#左边填充
-zfill() # 左边填充,不能指定符号

name = 'wangxiaolong'
print(name.center(20, "_"))
print(name.center(20,"*"))
print(name.center(20,"o"))

____wangxiaolong____
****wangxiaolong****
oooowangxiaolongoooo

name = 'Riany'
print(name.ljust(20,'*'))
print(name.rjust(20,"*"))
print(name.zfill(20))
Riany***************
***************Riany
000000000000000Riany

2.4 -count() #计数在字符串出现的次数。后面的数字为字符串的下标

name = 'wangxiaolong'
print(name.count("a"))
print(name.count('a', 1, 6))
2
1

2.5
-endswith() #判断已什么结尾
-startswith() #判断已什么结尾

name = 'wangxiaolong'
print(name.endswith('g'))
print(name.endswith('x'))
True
False

print(name.startswith('w'))
print(name.startswith('x'))
True
False

2.6
-find() #从什么位置查找,不存在显示-1
-index() #和find语法类似,但是不存在直接报错

name = 'wangxiaolong'
print(name.find('a'))
print(name.find('a', 3, 12))
print(name.find('e'))
1
6
-1
print(name.index('a'))
print(name.index('a', 3, 12))
print(name.index('e'))
1
6
substring not found

2.7
-format() #占位符替换为值
-format_map #占位符替换为值

text = 'I an {name}, age {num}.'
print(text.format(name='Rainy', num = 20))
I an Rainy, age 20.

print(text.format_map({'name':'Diudiu', "num":18}))
I an Diudiu, age 18.

2.8

-isalnum() # 判断字符串是否有特殊符号
-isalpha() #判断字符串是否为字母
-isdecimal()#判断是否是数字,不能判断特殊符号
-isdigit()#判断是否是数字,可以判断特殊符号
-isnumeric()#判断是否为数字,可以判断中文数
-isidentifier() #判断是否已字母,下划线开头
-isprintable()#判断字符串打印有不可显示的字符
-isspace() #判断是否全部是空格
-ististitle() #判断是否为标题(首字母大写)
-islower() #判断是否是小写
-isupper(). #判断是否全部是大写

a = 'asda123_*'
print(a.isalnum())
False
b = 'asd123'
print(b.isalnum())
True

B = '123qwe'
c = 'qwe'
print(B.isalpha())
print(c.isalpha())
False
True

a = '123qwe'
b = '1234'
print(a.isdecimal())
print(a.isdigit())
print(b.isdecimal())
print(b.isdigit())
False
False
True
True
c = '③'
print(c.isdecimal())
print(c.isdigit())
print(c.isnumeric())
False
True
True
a = '二'
print(a.isnumeric())
print(a.isdigit())
print(a.isdecimal())
True
False
False

a = 'def'
print(a.isidentifier())
b = '_name'
print(b.isidentifier())
c = 'name_'
print(c.isidentifier())
d = 'qwe'
print(d.isidentifier())
f = '1a123'
print(f.isidentifier())
True  a
True  b
True  c
True  d
False f


a = 'asdasfdsfefd'
print(a.isprintable())
b = 'asdasfa\nasdwq'
print(b.isprintable())
c = 'asdffsd\t'
print(c.isprintable())
True
False
False

a = 'absf'
print(a.isspace())
b = 'a bc '
print(b.isspace())
c = ' abc'
print(c.isspace())
d = ' '
print(d.isspace()) 
False
False
False
True

a = 'Process finished with exit code'
print(a.istitle())
b = a.title()
print(b)
print(b.istitle())
False
Process Finished With Exit Code
True

name = "Rainy"
print(name.lower())
print(name.islower())

name = "Rainy"
name1 = 'QWE'
print(name.upper())
print(name.isupper())
print(name1.isupper())

2.9 expandtabs() #把字符串从0开始往右位移N个字符,当出现Tab(\t)就会自动补全到N位。

test = 'Username\tEmail\tPasswd\nwangxiaolong\t136@163.com\twangxiaolong\nliuyan\t182@163.com\tdiudiu'
print(test.expandtabs(15))

Username       Email          Passwd
wangxiaolong   136@163.com    wangxiaolong
liuyan         182@163.com    diudiu

2.10
-join #将字符串的每个元素按照指定分隔符进行拼接

a = '铥丢是最漂亮的'
print("~".join(a))
print('&'.join(a))
铥~丢~是~最~漂~亮~的
铥&丢&是&最&漂&亮&的

2.11

  • upper() #小写转换为大写
name = "Rainy"
name1 = 'wangxiaolong'
print(name.upper())
print(name1.upper())
RAINY
WANGXIAOLONG

2.12 # 移除空白字符、/n、/t。指定字符
lstrip() #从左往右
rsprip()#从右往左
strip() #只要出现

name = '  Rainy  '
print(name.lstrip())
print(name.rsplit())
print(name.strip())
Rainy  
['Rainy']
Rainy
name1 = 'wangxiaolong'
print(name1.lstrip('wag'))
print(name1.rsplit('ong'))
print(name1.strip('wangxia'))
ngxiaolong
['wangxiaol', '']
olo

2.13
-maketrans # 创建对应关系
-translate #替换对应关系中的东西

a = 'wangxiaolong'
m = str.maketrans("wang",'1234')
print(a.translate(m))
1234xi2olo34

2.14 #按指定字符分割
partition() #从左往右分割第一个字符。不可以传参数(可以拿到指定字符)
rpartition()#从右往左分割第一个字符。不可传参数 (可以拿到指定字符)
split() #从左往右分割所有字符,可以指定分割次数(无法拿到指定字符)
rsplit #从右往左分割所有字符,可以指定分割次数(无法拿到指定字符)
splitlines() #只能通过换行符进行分割,True和False是否保留换行符。

a = 'testsadafsfsfs'
print(a.partition('s'))
print(a.rpartition('s'))
print(a.split('s',3))
print(a.rsplit('s',2))
('te', 's', 'tsadafsfsfs')
('testsadafsfsf', 's', '')
['te', 't', 'adaf', 'fsfs']
['testsadafsf', 'f', '']

a = 'sadfdsf\nfdsgfdgfdf\nasfdgfdgs'
print(a.splitlines())
print(a.splitlines(True))
print(a.splitlines(False))
['sadfdsf', 'fdsgfdgfdf', 'asfdgfdgs']
['sadfdsf\n', 'fdsgfdgfdf\n', 'asfdgfdgs']
['sadfdsf', 'fdsgfdgfdf', 'asfdgfdgs']

2.15 判断已什么开头或者结尾
startswith()#已什么开头
endswith()#已什么结尾

a = 'wangxiaolong'
print(a.startswith('wa'))
print(a.startswith('x'))
print(a.endswith('long'))
print(a.endswith('xia'))
True
False
True
False

2.16.
-swapcase() # 大小写转换

name = 'WangXiaoLong'
print(name.swapcase())
wANGxIAOlONG

2.17 替换
replace() #把某些参数替换为后面的,数字代表几次。

name = 'RainRainRain'
print(name.replace('R','W'))
print(name.replace('n','W',2))

列表的方法

列表转换为字符串

#1、列表中既有数字,也有字符串,需要手动for循环一个一个转换
a = [123,234,'asd','456']
s = ''
for i in a:
    s = s + str(i)
print(s)
123234asd456

#2、列表中全部都是字符串的时候,用join
b = ['123','abc','dfg']
print("".join(b))
123abcdfg

插入元素
append(). #追加
insert() #向指定位置插入一个元素

li = [11,12,14,15]
li.append('Rainy')
li.append('qwe')
print(li)
[11, 12, 14, 15, 'Rainy', 'qwe']

# li.insert(0,9)   
# print(li)
[9, 11, 12, 14, 15, 'Rainy', 'qwe']

删除列表中的值
clear() # 清空
pop()# #删除一个值,默认删除最后一个也可以指定下标位置,并可以获取到删除的值
remove() #删除一个指定的值,左边优先
del[] #删除一个值,按照下标删除(也支持切片操作)

li = [11,12,14,15]
li.clear()  #清空
print(li)
[]

li = [11,12,14,15]
print(li.pop())
print(li)
15
[11, 12, 14]
print(li.pop(2))   
print(li)
14
[11, 12]
li.remove(11)   
print(li)
[12, 14, 15]

del li[1]      
print(li)

列表反转

li = [11,16,12,14,15]
# li.reverse()    #将列表反转
# print(li)
# li.sort()    #从小到达排序
# print(li)
# li.sort(reverse=True)   #从大到小
# print(li)
[15, 14, 12, 16, 11]
[11, 12, 14, 15, 16]
[16, 15, 14, 12, 11]

元组

  1. 书写格式
    tu = (111,"alex",(11,22),[(33,44)],True,33,44,)
    一般写元组的时候,推荐在最后加入 ,
    元素不可被修改,不能被增加或者删除

  2. 索引
    v = tu[0]
    print(v)

  3. 切片
    v = tu[0:2]
    print(v)

  4. 可以被for循环,可迭代对象

tu = (111,"alex",(11,22),[(33,44)],True,33,44,)
for item in tu:
    print(item)
111
alex
(11, 22)
[(33, 44)]
True
33
44
  1. 转换
s = "asdfasdf0"
li = ["asdf","asdfasdf"]
tu = ("asdf","asdf")

v = tuple(s)
print(v)

v = tuple(li)
print(v)

v = list(tu)
print(v)

v = "_".join(tu)
print(v)

li = ["asdf","asdfasdf"]
li.extend((11,22,33,))
print(li)

6.元组的一级元素不可修改/删除/增加

tu = (111,"alex",(11,22),[(33,44)],True,33,44,)
tu[3][0] = 0000
print(tu)
(111, 'alex', (11, 22), [0], True, 33, 44)

字典

# dict
 dic = {
     "k1": 'v1',
     "k2": 'v2'
 }
print(die)
{'k1': 'v1', 'k2': 'v2'}

1 根据序列,创建字典,并指定统一的值

print(dict.fromkeys([1,2,3,4,5,6,7],[123,312,321]))
1: 123, 2: 123, 3: 123, 4: 123, 5: 123, 6: 123, 7: 123}

2 -get() 根据Key获取值,key不存在时,可以指定默认值(None)

a = {1:'a',
     3:'b',
     4:'c',
     5:'d'}
print(a.get(2,232143242342))
232143242342

输出keys,values
items() #全部输出keys,values
values() #只输出values
keys() # 只输出keys

a = {1:'a',
     3:'b',
     4:'c',
     5:'d'}
for i,o in a.items():
     print(i,o)
for i in a.values():
     print(i)
for i in a.keys():
     print(i)
3 b
4 c
5 d
a
b
c
d
1
3
4
5

删除
-pop(). #根据key的值删除value,当key不存在的时候,可以指定默认值。
-popitem() #随机删除一个值并可以获取。

a = {1:'a',
     3:'b',
     4:'c',
     5:'d'}
v = a.pop(122,111111)
print(a, v)
{1: 'a', 3: 'b', 4: 'c', 5: 'd'} 111111
b = a.pop(5)
print(a)
print(b)
{1: 'a', 3: 'b', 4: 'c'}
d

v = a.popitem()
print(v)
print(a)
(5, 'd')
{1: 'a', 3: 'b', 4: 'c'}

设置值
setdefault(). #当设置的key已存在,不设置,并返回当前的值 #当设置的key不不存在,设置值并返回当前的值

a = {1:'a',
     3:'b',
     4:'c',
     5:'d'}
v = a.setdefault(10,'e')
print(a)
print(v)
{1: 'a', 3: 'b', 4: 'c', 5: 'd', 10: 'e'}
e
v1 = a.setdefault(1,'t')
print(a)
print(v1)
{1: 'a', 3: 'b', 4: 'c', 5: 'd', 10: 'e'}
a

更新添加
update() #如果key存在,则更新。如果不存在则添加。

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

推荐阅读更多精彩内容