欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Python - 基本数据类型及其常用的方法之数字与字符串

程序员文章站 2023-08-23 09:41:39
数字(int): 1、int()(将字符串换为数字) 输出: 2、bit_length() (当前数字的二进制前面的零不算) 输出 字符串(str): 1、capitalize() 输出: 2、casefold() 和 lower() (转化大小写) 输出: lower() 只针对英文的大小写;ca ......

数字(int):

  1、int()(将字符串换为数字)

a = "123"
print(type(a), a)

b = int(a)
print(type(b), b)

num = "a"
# 使用 int 方法时默认转换为十进制数
# 通过base来指定转换后的类型
v = int(num, base=16)
print(v)

 输出:

<class 'str'> 123
<class 'int'> 123
10

 

   2、bit_length() (当前数字的二进制前面的零不算)

a1 = 2  # 0010
a2 = 3  # 0011
v1 = a1.bit_length()
v2 = a2.bit_length()
print(v1)
print(v2)

输出

2
2

 

字符串(str):

  1、capitalize()

test = "aiden"
# 首字母大写
v = test.capitalize()
print(v)

输出:

aiden

 

  2、casefold() 和 lower() (转化大小写)

test = "aiden"
v1 = test.casefold()
print(v1)

v2 = test.lower()
print(v2)

输出:

aiden
aiden

lower() 只针对英文的大小写;casefold() 可以转换很多未知的大小写对应关系

 

  3、center(); ljust(); rjust

test = "aiden"
# 设置宽度, 并将内容居中
# 20 代指总长度
# * 空白位置的填充(一个字符,包括中文),默认为空
v = test.center(20, "*")
print(v)

输出:

*******aiden********

 

test = "aiden"
v1 = test.ljust(20, "*")
v2 = test.rjust(20, "*")
print(v1)
print(v2)

输出:

aiden***************
***************aiden

 

  4、count()

test = "aidenaiden"
# 在字符串中查找子列的个数
# 2 表示从第 2 个开始;4 表示到第 3 个时结束(从零开始计数)
v1 = test.count("a")
v2 = test.count("de", 2, 4)
print(v1)
print(v2)

输出:

2
1

 

  5、encode()

 

  6、decode()

 

  7、endswith() 和 startwith()

test = "aidenaiden"
# 以什么开始(可设置开始和结束的参数)
v = test.startswith("ai", 0, 2 )
print(v)
# 以什么结尾(可设置开始和结束的参数)
v = test.endswith("d")
print(v)

输出:

true
false

 

  8、find()

# 从开始往后找,找到第一个后获取其位置(可设置开始和结束的参数)
test = "aidenaiden"
v = test.find("de",2, 4 )
print(v)

输出:

2

 

  9、formate() 和 formate_map()

# 格式化:将字符中的占位符替换为指定的值
test = "my name is {name},my age is {age}"
print(test)
v = test.format(name="aiden", age=18)
print(v)

输出:

my name is {name},my age is {age}
my name is aiden,my age is 18

 

# 格式化:将字符中的占位符替换为指定的值
# 可以指定位序(空则默认从零开始)
test = "my name is {0},my age is {1}"
print(test)
v = test.format("aiden", 18)
print(v)

输出:

my name is {0},my age is {1}
my name is aiden,my age is 18

 

# 传入的值为字典
test = "my name is {name},my age is {age}"
v = test.format_map({"name": "aiden", "age": 18})
print(v)

输出:

my name is aiden,my age is 18

 

  10、isalnum()

# 字符串中是否只包含数字和字母
test1 = "agfgdge123+-"
test2 = "aiden"
v1 = test1.isalnum()
v2 =test2.isalnum()
print(v1)
print(v2)

输出:

false
true

 

  11、expendtabs()

# 断句输出\t前的字符若不够则空格补齐(及字符串和\t长度相加为 10 遇到\n换行)
test = "name\tage\taddress\temail\naiden\t18\twenzhou\t@qq.com\naiden\t18\twenzhou\t@qq.com\n"
v = test.expandtabs(10)
print(v)

输出:

name      age       address   email
aiden     18        wenzhou   @qq.com
aiden     18        wenzhou   @qq.com

 

  12、isalpha()

# 判断字符串是否由字母组成(包括汉字)
test1 = "天fag"
test2 = "12afag"
v1 = test1.isalpha()
v2 = test2.isalpha()
print(v1)
print(v2)

输出:

true
false

 

  13、isdecimal(), isdigital(), isnumeric()

# 判断当前输入的是否是数字
test = "123"
v1 = test.isdecimal()
v2 = test.isdigit()
v3 = test.isnumeric()
print(v1, v2, v3)

输出:

true true true

三个都能输出数字

# 判断当前输入的是否是数字
test = "123②"
v1 = test.isdecimal()
v2 = test.isdigit()
v3 = test.isnumeric()
print(v1, v2, v3)

输出:

false true true

isdigit() 可以输出符号数字(②)

# 判断当前输入的是否是数字
test = "123②二"
v1 = test.isdecimal()
v2 = test.isdigit()
v3 = test.isnumeric()
print(v1, v2, v3)

输出:

false false true

isnumeric() 可以输出中文数字

 

  14、isprintable()

# 输出时是否有不可见的字符
test1 = "abcd"
test2 = "abc\td"
v1 = test1.isprintable()
v2 = test2.isprintable()
print(v1, v2)

输出:

true false

 

  15、isspace()

# 判断是否全部为空格
test1 = "ab cd"
test2 = "    "
v1 = test1.isspace()
v2 = test2.isspace()
print(v1, v2)

输出:

false true

 

  16、title() 和 istitle()

# istitle()判断是否为标题
# title()将每个字符串的首字母大写
test = "return true if the string is a title-cased string, false otherwise."
v1 = test.istitle()
print(v1)
v2 = test.title()
print(v2)
v3 = v2.istitle()
print(v3)

输出:

false
return true if the string is a title-cased string, false otherwise.
true

 

  17、join()(别的数据类型也可以用)

# 将字符串中的每一个元素按照指定的字符进行拼接
test = "或许爱你还能算一种天分"
print(test)
# t = " "
v = " ".join(test)
print(v)

输出:

或许爱你还能算一种天分
或 许 爱 你 还 能 算 一 种 天 分

  18、lower(), islower(); upper(), isupper()

test = "aiden"
v1 = test.lower()
print(v1)
v1 = v1.islower()
print(v1)

输出

aiden
true

 

test = "aiden"
v1 = test.upper()
print(v1)
v1 = v1.isupper()
print(v1)

输出:

aiden
true

 

  19、strip(), lstrip(), rstrip()

# 默认删除空白(空格,\t, \n)
# strip 删除两边
# lstrip 删除左边
# rstrip 删除右边
test = "\n aiden \t"
v1 = test.strip()
v2 = test.lstrip()
v3 = test.rstrip()
print(v1)
print(v2)
print(v3)

输出:

aiden
aiden

     aiden

也可以删除指定字符

# 移除指定字符
# 按照有限最多匹配
test = "xaiendenx"
v1 = test.strip("x")
v2 = test.lstrip("x")
v3 = test.rstrip("enxd")
print(v1)
print(v2)
print(v3)

输出:

aienden
aiendenx
xai

 

  20、maketrans() 和 translate()

# 将字符串按照对应关系替换
test1 = "aeiou"
test2 = "12345"
test = "asqwoeradurqoienuato"
# 设置对应关系
m = str.maketrans(test1, test2)
v = test.translate(m)
print(v)

输出:

1sqw42r1d5rq432n51t4

 

  21、partition() 和 rpartition()

# 只能将字符串按照指定的字符串分割成三份
test = "aidden"
v1 = test.partition("d")
v2 = test.rpartition("d")
print(v1)
print(v2)

输出:

('ai', 'dd', 'en')
('aid', 'd', 'en')

 

  22、split(), rsplit(), splitlines()

# 将字符串按照指定的字符串和指定的次数分隔
# 但不能获取指定的分割字符串
test = "adaidenda"
v1 = test.split("d", 2)
v2 = test.rsplit("d", 2)
print(v1)
print(v2)

输出:

['a', 'ai', 'enda']
['adai', 'en', 'a']

 

# 只根据换行符号分割
test = "ad\naiden\nda"
v1 = test.splitlines() # 默认false
v2 = test.splitlines(true)
print(v1)
print(v2)

输出:

['ad', 'aiden', 'da']
['ad\n', 'aiden\n', 'da']

 

  23、swapcase()

# 大小写装换
test = "aiden"
v1 = test.swapcase()
print(v1)

输出:

aaiden

 

  24、replace()

# 将字符串中的字符替换为指定的字符
# 可指定替换的个数
test = "aidenaidenaiden"
v1 = test.replace("den", "b")
v2 = test.replace("den", "b", 2)
print(v1)
print(v2)

输出:

aibaibaib
aibaibaiden

 

  25、将数字转换为字符串

# 数字转换为字符串
s = 123
v = str(s)
print(v, type(v))

输出:

123 <class 'str'>

 

  26、列表转化成字符串

# 列表中只有字符串时
li = ["aiden", "nihao", "alix"]
v = "".join(li)  # join本质上使用for循环
print(v)

输出:

aidennihaoalix

 

# 列表中既有字符串又有数字时
# 需要自己写for循环
li = [123, "nihao", "alix"]
s = ""
for i in li:
    s += str(i)
print(s)

输出:

123nihaoalix

 

  27、其他(别的数据类型也可以用)

test = "aiden"
# 索引
print(test[0])
# 切片
print(test[0:2])  # >=0  <2
print(test[0:-1])
# for 循环
for i in test:
    print(i)

输出:

a
ai
aide
a
i
d
e
n

a
ai
ai

字符串一旦创建不可修改;一旦拼接或者修改都会重新生成字符串。