【Python从入门到人工智能】14个必会的Python内置函数(7)——数据格式化处理 综合应用场景

news2024/10/10 10:33:01

 
总觉得忍一忍就会好起来。真笨,人家不就是觉得你会忍一忍,所以才这样对你吗?当我们凶狠地对待这个世界的时候,才会发现这个世界,突然变得温文尔雅了。——余华《在细雨中呼喊》

 

🎯作者主页: 追光者♂🔥

        

🌸个人简介:
 
💖[1] 计算机专业硕士研究生💖
 
🌟[2] 2022年度博客之星人工智能领域TOP4🌟
 
🏅[3] 阿里云社区特邀专家博主🏅
 
🏆[4] CSDN-人工智能领域优质创作者🏆
 
📝[5] 预期2023年10月份 · 准CSDN博客专家📝  
 

  • 无限进步,一起追光!!!

        

🍎感谢大家 点赞👍  收藏⭐   留言📝!!!

附:

  • 1.Python内置函数系统学习(1)——数据转换与计算(详细语法参考 + 参数说明 + 具体示例)
  • 2.Python内置函数系统学习(2)——数据转换与计算(详细语法参考 + 参数说明 + 具体示例),详解max()函数实例 | 编程实现当前内存使用情况的监控
  • 3.Python内置函数系统学习(3)——数据转换与计算(详细语法参考 + 参数说明 + 具体示例)详解 min()函数 | lambda 真的牛啊
  • 4.【Python从入门到人工智能】16个必会的Python内置函数(4)——数据转换与计算(详细语法参考 + 参数说明 + 具体示例)
  • 5.【Python从入门到人工智能】14个必会的Python内置函数(5)——输入输出(详细语法参考 + 参数说明 + 具体示例)| 计算机八大学报都是什么?| 知识图谱&区块链技术
  • 6.【Python从入门到人工智能】14个必会的Python内置函数(6)——打印输出(详细语法参考 + 参数说明 + 具体示例)| 附:Python输出表情包

🌿本篇首先分享Python打印输出的综合应用场景及其相关知识并给出实现代码,具体地包含中英文多列对齐输出(zip函数的应用)、通过print的多行打印模拟实现一个应用程序的主要应用界面、通过while循环和width实现分行输出国际列车的站名。然后初步分享了Python中格式化处理的一些知识,如格式转换、生成数据编号、格式化十进制整数、格式化浮点数、格式化百分数/科学记数法/金额等。注意,这不仅是Python基础,也是人工智能/机器学习基础知识哦!让我们一起来学习吧!

👀目录

  • 🍄一、打印输出 & 综合应用场景
    • 🍑1.1 场景二:中英文多列对齐输出
    • 🍑1.2 场景三:实现程序主界面
    • 🍑1.3 场景四:分行输出K3国际列车的站名(含问题记录和解决)
  • 🍄二、格式化处理
    • 🍑2.1 语法参考 & 参数说明
    • 🍑2.2 示例
      • 🍒2.2.1 格式转换
      • 🍒2.2.2 生成数据编号
      • 🍒2.2.3 格式化十进制整数
      • 🍒2.2.4 格式化浮点数
      • 🍒2.2.5 格式化百分数
      • 🍒2.2.6 格式化科学记数法
      • 🍒2.2.7 格式化金额

🍄一、打印输出 & 综合应用场景

此前曾分享了打印输出函数print的综合应用场景一以及其较为高级的语法结构。本篇先继续分享print的剩余几个示例的综合应用场景。

🍑1.1 场景二:中英文多列对齐输出

中英文多列对齐输出 德国、法国、英国2018年汽车销量数据。读取多个列表的数据,对数据输出时,如果进行格式化处理,输出不对齐,影响输出效果。代码如下:

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/16/0016 10:37
gem = [["大众", 643518], ["奔驰", 319163], ["宝马", 265051], ["福特", 252323], ["雪铁龙", 227967], ["奥迪", 255300]]

fra = [["雪铁龙", 698985], ["雷诺", 547704], ["大众", 259268], ["福特", 82633], ["宝马", 84931], ["奔驰", 73254]]

eng = [["福特", 254082], ["大众", 203150], ["雪铁龙", 177298], ["奔驰", 172238], ["宝马", 172048], ["奥迪", 143739]]

for item1, item2, item3 in zip(gem, fra, eng):
    print(item1[0], item1[1], "  ", item2[0], item2[1], "  ", item3[0], item3[1])

在这里插入图片描述
 

如果数据中包含中文,则输出的列数据无法排列整齐。使用 对齐函数ljust() 对数据进行居左对齐显示,也无法对齐数据。因为中文占据的字符长度与英文不同,此时可以使用制表符 ’\t’ 来进行对齐输出。代码如下:

依然是针对上述的 gem,fra,eng 嵌套列表:

for item1,item2,item3 in zip(gem,fra,eng):

    item11 = item1[0].ljust(8)

    item12 = str(item1[1]).ljust(8)

    item21 = item2[0].ljust(8)

    item22 = str(item2[1]).ljust(8)

    item31 = item1[0].ljust(8)

    item32 = str(item3[1]).ljust(8)

    print(item11 +"\t",item12+"\t","  ",item21+"\t",item22+"\t","  ",item31+"\t",item32)

数据对齐结果 输出如下:
在这里插入图片描述

🍑1.2 场景三:实现程序主界面

利用print函数,可以输出程序界面,代码如下:

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/16/0016 10:45

# 实现程序主界面
print("""\033[1;35m

  ****************************************************************

                        企业编码生成系统

  ****************************************************************

      1.生成6位数字防伪编码 (213563型)

      2.生成9位系列产品数字防伪编码(879-335439型)

      3.生成25位混合产品序列号(B2R12-N7TE8-9IET2-FE35O-DW2K4型)

      4.生成含数据分析功能的防伪编码(5A61M0583D2)

      5.半智能防伪码自动生成(按指定样式数量自动生成)

      6.企业粉丝防伪码抽奖

      0.退出系统

  ================================================================

  说明:通过数字键选择菜单

  ================================================================

\033[0m""")

执行以后,我们可以得到如下的“程序主界面”输出结果:

在这里插入图片描述

🍑1.3 场景四:分行输出K3国际列车的站名(含问题记录和解决)

如果字符串过长,希望多行显示,可以通过切片技术实现多行的输出,如下代码,设置width变量的值,即可实现对K3国际列车的站名多行输出。代码如下:

#coding=utf-8
# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/16/0016 10:48


# 场景四:分行输出K3国际列车的站名

k3 = '北京、张家口南、集宁南、朱日和、二连、扎门乌德、赛音山达、乔伊尔、乌兰巴托、宗哈拉、达尔汗、苏赫巴托、多卓尔内、纳乌什基、吉达、乌兰乌德、斯柳江卡、伊尔库茨克、集马、尼日涅乌丁斯克、伊兰斯卡雅、克拉斯诺亚尔斯克、马林斯克、泰加、新西伯利亚、巴拉宾斯克、鄂木斯克、伊希姆、秋明、斯维尔德洛夫斯克、彼尔姆、巴列集诺、基洛夫、高尔基、弗拉基米尔、莫斯科'

width = 22  # 设置每行22个字的输出
# width = 30

len1 = 0

k3line = ""

while len(k3) > width:
    k3line = k3[0:width]

    k3 = k3[width:len(k3)]

    print(k3line)

print(k3[0:len(k3)])

这是执行上述程序,设置每行22个字的输出 得到的结果:(顿号 也算)
在这里插入图片描述

注意:上面的程序,是在PyCharm中执行的。但是,执行时需要在程序的第一行 添加 #coding=utf-8 ,若不添加,则会报下述错误:SyntaxError: Non-UTF-8 code starting with '\xe5' in file H:\Python学习专用\个人练习\临时保存\Python内置函数(6)\test_3.py on line 7, but no encoding declared; see https://python.org/dev/peps/pep-0263/ for details
在这里插入图片描述
这是因为 Python的默认编码是ASCII码,如果文件中含有中文,应在文件开头加上一句:#coding=utf-8

另外要注意,若coding和=之间有空格,如**#coding =utf-8**,会可能有错误提示:SyntaxError: Non-ASCII character '\xe7' in file , but no encoding declared; see http://www.python.org/peps/pep-0263.html for details (或者是依然报上述错误的提示)

那么同样的道理,设置每行30个字的输出,只需要 width = 30 即可:
在这里插入图片描述

🍄二、格式化处理

🍑2.1 语法参考 & 参数说明

语法参考:

format() 可以对数据进行格式化处理操作,语法如下:

format(value, format_spec)

format_spec为格式化解释。当参数format_spec为空时,等同于函数str(value)的方式。value为要转换的数据。format_spec可以设置非常复杂的格式转换参数,实现比较完备的数据格式处理模板。format_spec的编写方式如下形式:

format_spec ::= [[fill]align][sign][#][0][width][,][.precision][type]

format_spec格式控制符可以分为文字对齐、填充值、标志设置、格式化、类型转换、千位符(数字分组)等主要应用。细化分类说明如下图所示。

format_spec 格式控制符细化分类:
在这里插入图片描述

主要参数说明:

  • fill(填充值):此处可以填写任何字符,通常与align、width一起使用,实现指定位数字符填充,通常格式、填充效果及位置分别如下两图所示。、

fill 填充格式:
在这里插入图片描述

fill 填充效果及位置:
在这里插入图片描述

通常用0、*、#等进行填充。如果不写填充值,则使用默认填充值,默认填充值为空格。代码如下:

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/17/0017 8:02

print(format(99, '@<10'))  # 用@填充,宽度为10个空格

print(format(99, '@>10'))  # 用@填充,宽度为10个空格

输出结果为:
在这里插入图片描述

继续来看参数说明:

  • align(对齐方式):指在width(数字宽度)内输出时的对齐方式,分别使用<、>、^和=四个符号表示左对齐、右对齐、居中对齐和数字填充(只用于数字,在符号后进行补齐)。

  • width(数字宽度):指设定输出字符宽度,如果数据的实际位数比width指定宽度值大,则使用数据实际的长度。如果该值的实际位数小于指定宽度,则位数将设定的fill值填充或设定的0值填充,如果没有设置填充值,则用空格填充

来看个小测试:

s = "PYTHON"

print(format(s, '10'))  # 没有标志符,如果是字符串则默认左对齐,不足宽度部分默认用空格填充

print(format(10.24, '10'))  # 没有标志符,如果是数字则默认右对齐,不足宽度部分默认用空格填充

print(format(s, '0>10'))  # 右对齐,不足指定宽度部分用0号填充

print(format(s, '>04'))  # 右对齐,因字符实际宽度大于指定宽度4,不用填充

print(format(s, '*>10'))  # 右对齐,不足部分用“*”号填充

print(format(s, '>010'))  # 右对齐,不足部分用0号填充

print(format(s, '>10'))  # 右对齐,默认用空格填充

print(format(s, '<10'))  # 左对齐,默认用空格填充

print(format(s, '<010'))  # 左对齐,不足部分用0号填充

print(format(s, '@^10'))  # 中间对齐,不足部分用“@”填充,宽度为10个空格

print(format(10.24, '0<10'))  # 左对齐,不足部分用0号填充

print(format(10.24, '@^10'))  # 右对齐,不足部分用“@”填充

print(format(10.24, '0>10'))  # 右对齐,不足部分用0号填充

print(format(-10.24, '0=10'))  # 右对齐,负号后面不足部分用0号填充,

我在注释中已经解释的很清楚了,大家可以自行验证~

得到的输出为:
在这里插入图片描述

继续进行 参数说明

  • Precision(精度):精度由小数点(.)开头。对于浮点数,精度表示小数部分输出的有效位数对于字符串,精度表示输出的最大长度。 Precision(精度)通常和Type(类型)配合起来使用。

  • Type(类型):表示输出字符串、整数和浮点数类型的格式规则,默认为字符型s。对于整数类型,输出格式包括7 种
    (1)b: 输出整数的二进制方式;
    (2)c: 输出整数对应的 Unicode 字符;
    (3)d: 输出整数的十进制方式;
    (4)n: 输出整数的十进制方式;
    (5)o: 输出整数的八进制方式;
    (6)x: 输出整数的小写十六进制方式;
    (7)X: 输出整数的大写十六进制方式;
    对于浮点数类型,输出格式包括7种
    (1)e: 输出浮点数对应的小写字母 e 的指数形式;
    (2)E: 输出浮点数对应的大写字母 E 的指数形式;
    (3)f: 输出浮点数的浮点表示形式,默认保留6位小数
    (4)F: 输出浮点数的浮点表示形式,默认保留6位小数,无穷大转换成大写字母’INF’
    (5)g,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)。
    (6)G,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置 (如果是科学计数则是E)
    (7)%: 输出浮点数的百分形式。

🍑2.2 示例

🍒2.2.1 格式转换

使用format()函数可以实现格式转换。如果format()函数的参数format_spec未提供,则默认为将其他格式数据格式化为字符型,和调用str(value)效果相同。如:

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/17/0017 8:19

a = 3.14
a = format(a)  # 使用format ()函数将浮点数转换成字符
print(a, "type(a):", type(a))

在这里插入图片描述
 

这和str()函数的效果是相同的:

b = 3.14
b = str(3.14)  # 使用str()函数将浮点数转换成字符
print(b,"type(b):",type(b))

在这里插入图片描述
 

再来看个将 日期 格式化为字符输出的示例:

# 将日期格式化为字符
import datetime

print(format(datetime.datetime.utcnow().strftime("%Y-%m-%d   %H:%M:%S")))

在这里插入图片描述
 
 
 

设置参数format_spec的值,可以进行相应数据类型的格式化,字符串可以提供的参数为’s’ 。十进制整形提供的参数为’d’ 和’n’,二进制的参数为’b’,八进制的参数为’o’,十六进制小写的参数为 ‘x’ ,十六进制大写的参数为 ‘X’ ,ASC码的参数为’c’,浮点数的参数为’f’。以上格式化后的数据类型都为字符型,举例如下:

print(format(12.2, 'f'))  # 转换成浮点数,默认为小数保留6位
print(format(12, 'd'))  # 转换成十进制
print(format(13))  # 不带参数默认为10进制
print(format(13, 'n'))  # 转换成十进制数
print(format(13, 'b'))  # 转换成二进制
print(format(65, 'c'))  # 转换unicode成字符
print(format(97, 'c'))  # 转换unicode成字符
print(format(8750, 'c'))  # 转换unicode成字符
print(format(12, 'o'))  # 转换成八进制
print(format(12, 'x'))  # 转换成十六进制小写字母表示
print(format(12, 'X'))  # 转换成十六进制大写字母表示

输出如下:
在这里插入图片描述

🍒2.2.2 生成数据编号

利用format()函数实现数据编号。对数据进行编号,也是对字符串格式化操作的一种方式,使用format()方法可以对字符串进行格式化编号。只需设置填充字符(编号通常设置0),设置对齐方式时可以使用 <>^ 符号表示左对齐、右对齐和居中对齐,对齐填充的符号在“宽度”范围内输出时填充,即可。对数字1进行3位编号,右对齐,需要设置format()方法的填充字符为0,对齐方式为右对齐,宽度为3。具体代码为:

print(format(1, '0>3'))  # 001
print(format(1, '>03'))  # 001
print(format(15, '0>5'))  # 00015

 
 

要生成的编号通常比较复杂,如根据当天的日期建立编号,或者批量生成编号,或者将给定的批量数据中的数字转换成位数固定的编号,下面给出实现如上编号的实现方法:

import datetime

# 时间+编号

wx = datetime.datetime.now().date()

now = datetime.datetime.now()

print(str(wx), format(1, '0>3'))  # 年月日 +3位编号

print(format(now, '%Y-%m-%d'), format(1, '0>3'))  # 年月日 +3位编号

print(format(now, '%Y%m%d'), 'NO' + format(1, '0>3'))  # 年月日+NO+3位编号

print(format(now, '%d'), 'NO' + format(1, '0>3'))  # 日期+NO+3位编号

print(format(now, '%H%M'), 'NO' + format(1, '0>3'))  # 时钟+分 +NO+3位编号

输出:
在这里插入图片描述

 
 

# 批量生成编号

for i in range(1, 6):
    print(format(i, '0>2'))

在这里插入图片描述

 
 
巧用for循环来 格式化列表编号:

# 格式化列表编号
# 对已有非编号数字进行格式化编号
nba = {1: '伦纳德', 2: '哈登', 3: '乔治', 4: '追光者♂'}
for key, value in nba.items():
    print(format(key, '0>3'), value)

在这里插入图片描述

 
 

要实现嵌套编号,如A001-A005,B001-B005,C001-005的嵌套编号。代码如下:

for i in range(65, 69):
    for j in range(1, 6):
        data = chr(i) + format(j, '0>3') + ' '
        print(data, end='')
    print()

在这里插入图片描述

🍒2.2.3 格式化十进制整数

对于不同的类型数据,format函数的参数format_spec提供的值都不一样,对于十进制整数,整形数值可以提供的参数有’d’、’n’。具体如下:

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/17/0017 8:40

print(format(99, '8d'))  # 8位整数显示,不足部分整数前用空格填充
print(format(99, '+d'))  # 格式化为带符号整数显示数据
print(format(-99, '8d'))  # 格式化为8位带符号整数显示,补位空格放到符号前
print(format(99, '=8d'))  # 格式化为8位正整数,用空格补位
print(format(-99, '=8d'))  # 格式化为8位负整数,不足部分在负号后填充
print(format(99, '+8d'))  # 格式化为8位正整数,不足部分在符号前填充
print(format(-99, '8d'))  # 格式化为8位负整数,不足部分在符号前填充

在这里插入图片描述
 
 

print(format(99, '>10'))  # 右对齐,宽度为10个空格
print(format(99, '<10'))  # 左对齐,宽度为10个空格
print(format(99, '010'))  # 用0填充空格,宽度为10个空格
print(format(99, '@<10'))  # 用@填充空格,宽度为10个空格
print(format(99, '@>10'))  # 用@填充空格,宽度为10个空格
print(format(+99, '=10'))  # 用@填充空格,宽度为10个空格
print(format(99, '0^10'))  # 用@填充空格,宽度为10个空格

在这里插入图片描述

 
 

s = 133

print(format(s, '0>10'))  # 右对齐,不足指定宽度部分用0号填充
print(format(s, '>04'))  # 右对齐,因字符实际宽度大于指定宽度4,不用填充
print(format(s, '*>10'))  # 右对齐,不足指定宽度部分用*号填充
print(format(s, '>010'))  # 右对齐,指定0标志位填充
print(format(s, '>10'))  # 右对齐,没指定填充值,用默认值空格填充
print(format(s, '+^30'))  # 居中对齐,用+号填充不足部分
print(format(s, '*<8'))  # 右对齐,不足指定宽度部分用*号填充
print(format(s, '08'))  # 右对齐,指定0标志位填充

在这里插入图片描述

🍒2.2.4 格式化浮点数

对于浮点数类型,可以提供的参数有 ‘e’ ‘E’ ‘f’ ‘F’ ‘g’ ‘G’ ‘n’ ‘%None输出格式。

用 f 表示浮点类型,并可以在其前边加上精度控制:用于控制输出宽度。这里由于输出位数大于宽度,就按实际位数输出了。还可以为浮点数指定符号,+ 表示在正数前显示+,负数前显示 -;(空格)表示在正数前加空格,在负数前加 -;- 与什么都不加({:f})时一致:.3f 表示浮点数的精度为3(小数位保留3位).3 指定除小数点外的输出位数。

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/17/0017 8:44

# 格式化浮点数
print(format(628, '.1f'))  # 格式化为保留1位小数的浮点数

print(format(628, '.2f'))  # 格式化为保留2位小数的浮点数

print(format(3.14159, '.1f'))  # 格式化为保留1位小数的浮点数

print(format(3.14159, '.2f'))  # 格式化为保留2位小数的浮点数

print(format(3.14159, '.5f'))  # 格式化为保留5位小数的浮点数

print(format(-3.14159, '.3f'))  # 格式化为保留1位小数的浮点数

print(format(3.1415926535898, 'f'))  # 默认精度保留6位小数

print(format(3.14159, 'f'))  # 默认精度保留6位小数,不足部分用空格填充

在这里插入图片描述
 
 
 

print(format(3.14159, '+.3f'))  # 格式化为保留3位小树带符号的浮点数
print(format(3.14159, '>8.2f'))  # 右对齐,保留三位小数
print(format(3.14159, '<10.2f'))  # 左对齐,宽度为10,保留2位小数,不足空格填充
print(format(3.14159, '<.3f'))  # 左对齐,保留3位小数点
print(format(3.14159, '@>10.3f'))  # 右对齐,用@填充不足位置
print(format(-3.14159, '=10.2f'))  # 格式化为保留2位小数的10位数,默认用空格填充
print(format(-3.14159, '0=10.2f'))  # 格式化为保留2位小数的10位数,空格用0填充
print(format(3.14159, '0^10.2f'))  # 保留2位小数的10位数,居中显示,空格用0填充

在这里插入图片描述

🍒2.2.5 格式化百分数

在格式化解释中单独或者在精度之后添加“%”号,可以实现用百分数显示浮点数,如:

# 昵 称:XieXu & CSDN@追光者♂
# 时 间: 2023/4/17/0017 8:51

# 格式化百分数
print(format(0.161896, '%'))  # 将小数格式化成百分数
print(format(0.161896, '.2%'))  # 格式化为保留两位小数的百分数
print(format(0.0238912, '.6%'))  # 格式化为保留六位小数的百分数
print(format(2 / 16, '.2%'))  # 格式化为保留两位小数的百分数
print(format(3.1415926, '.1%'))  # 格式化为保留一位小数的百分数
print(format(0.161896, '.0%'))  # 格式化为保留整数的百分数
print(format(0.0238912, '8.6%'))  # 格式化为保留六位小数的八位百分数
print(format(0.0238912, '>8.3%'))  # 格式化为保留三位小数的八位百分数

在这里插入图片描述

🍒2.2.6 格式化科学记数法

如果要将浮点数采用科学记数法表示,可以在格式化解释中使用“e”和“E”或者“g”和“G”。‘e’ 为通用的幂符号,用科学计数法打印数字,用’e’表示幂。使用’g’时,将数值以fixed-point格式输出。当数值特别大的时候,用幂形式打印。

# 格式化科学记数法
# e和E

print(format(3141592653589, 'e'))  # 科学计数法,默认保留6位小数
print(format(3.14, 'e'))  # 科学计数法,默认保留6位小数
print(format(3.14, '0.4e'))  # 科学计数法,默认保留6位小数
print(format(3141592653589, '0.2e'))  # 科学计数法,保留2位小数
print(format(3141592653589, '0.2E'))  # 科学计数法,保留2位小数,采用大写E表示

# g和G
print(format(3.14e+1000000, 'F'))  # 小数点计数法,无穷大转换成大小字母
print(format(3141592653589, 'g'))  # 科学计数法,保留2位小数
print(format(314, 'g'))  # 科学计数法,保留2位小数
print(format(3141592653589, '0.2g'))  # 科学计数法,保留2位小数,采用大写E表示
print(format(3141592653589, 'G'))  # 小数点计数法,无穷大转换成大小字母
print(format(3.14e+1000000, 'g'))  # 小数点计数法,无穷大转换成大小字母

在这里插入图片描述

🍒2.2.7 格式化金额

format()函数提供千位分隔符用逗号还能用来做金额的千位分隔符。如果要实现通常格式化后金额前面带上相关货币的符号,需要在该函数前面手动加上相应货币符号。如:

# 格式化金额
print('$' + format(1201398.2315, '.2f'))  # 添加美元符号,小数保留两位
print(chr(36) + format(1201398.2315, '.2f'))  # ASCII码添加美元符号,小数保留两位
print('¥' + format(78088888, ','))  # 添加人民币符号,用千位分隔符进行区分金额
print('£' + format(7908.2315, '.2f'))  # 添加英镑符号,用千位分隔符进行区分
print('€' + format(7908.2315,
                   ',.2f'))  # 添加欧元符号,保留两位小数,千位分隔print( chr(8364) + format(1201398.2315,'.2f'))   # 添加欧元符号,保留两位小数
print(chr(0x20ac) + format(1201398.2315, ',f'))  # 使用十六进制编码添加欧元符号

那么得到的输出效果如下:
在这里插入图片描述


篇幅所限,本篇暂时分享到此哦~

此外,本篇记录的所有代码,也已经上传至资源,大家可以在我主页的资源内搜索进而下载哦~

 


 

🍒 热门专栏推荐

  • 🥇Python&AI专栏:【Python从入门到人工智能】
  • 🥈前端专栏:【前端之梦~代码之美(H5+CSS3+JS.】
  • 🥉文献精读&项目专栏:【小小的项目 (实战+案例)】
  • 🍎C语言/C++专栏:【C语言、C++ 百宝书】(实例+解析)
  • 🍏Java系列(Java基础/进阶/Spring系列/Java软件设计模式等)
  • 🌞问题解决专栏:【工具、技巧、解决办法】
  • 📝 加入Community 一起追光:追光者♂社区

 

持续创作优质好文ing…✍✍✍

 

记得一键三连哦!!!

 

求关注!求点赞!求个收藏啦!

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/790357.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ElementUI 实现动态表单数据校验(已解决)

文章目录 &#x1f34b;前言&#xff1a;&#x1f34d;正文1、探讨需求2、查阅相关文档&#xff08;[element官网](https://element.eleme.cn/#/zh-CN/component/form)&#xff09;官方动态增减表单项示例3、需求完美解决4、注意事项 &#x1f383;专栏分享&#xff1a; &#…

Hello,Vector DB|可能是最易上手的 Faiss 教程

大家会不会有这样的疑问&#xff1a; 网易云音乐是如何根据我的音乐口味推荐相似歌曲的&#xff1f;淘宝是如何判断我的购买喜好的&#xff1f;手机相册又是如何识别照片中的人脸&#xff0c;并将同一个人的照片归为同一组的&#xff1f; 其实&#xff0c;实现这一切的背后技术…

【nginx】nginx之location规则详解:

文章目录 一、语法规则&#xff1a;二、优先级&#xff1a;三、验证&#xff1a;1、精确匹配&#xff1a;2、通过^~方式实现匹配&#xff1a;3、通过”~”方式实现匹配&#xff1a;4、通过"~*"方式实现匹配:5、”!~*” 和”!~” 不常用&#xff0c;再次不做介绍6、通…

JWT token

一、为什么使用JWT&#xff1f; 随着分布式web应用的普及&#xff0c;通过session管理用户登录状态成本越来越高&#xff0c;因此慢慢发展成token的方式做登录身份验证&#xff0c;然后通过token去取redis中的缓存的用户信息&#xff0c;随着之后jwt的出现&#xff0c;校验方式…

vue/cli 自定义配置

vue/cli 自定义配置 1、更改默认的端口号8080 只需要更改vue.config.js文件 1、更改默认的端口号8080 只需要更改vue.config.js文件

2023年基准Kubernetes报告:6个K8s可靠性失误

云计算日益成为组织构建应用程序和服务的首选目的地。尽管一年来经济不确定性的头条新闻主要集中在通货膨胀增长和银行动荡方面&#xff0c;但大多数组织预计今年的云使用和支出将与计划的相同&#xff08;45%&#xff09;&#xff0c;或高于计划的&#xff08;45%&#xff09;…

Vite+Typescript+Vue3学习笔记

ViteTypescriptVue3学习笔记 1、项目搭建 1.1、创建项目(yarn) D:\WebstromProject>yarn create vite yarn create v1.22.19 [1/4] Resolving packages... [2/4] Fetching packages... [3/4] Linking dependencies... [4/4] Building fresh packages...success Installed…

MyBatisPlus之DQL编程控制

MyBatisPlus之DQL编程控制 1. 条件查询方式1.1 条件查询1.1.1 方式一&#xff1a;按条件查询1.1.2 方式二&#xff1a;lambda格式按条件查询1.1.3 方式三&#xff1a;lambda格式按条件查询&#xff08;推荐&#xff09; 1.2 组合条件1.2.1 并且关系&#xff08;and&#xff09;…

【算法 -- LeetCode】(027) 移除元素

1、题目 给你一个数组 nums 和一个值 val&#xff0c;你需要 原地 移除所有数值等于 val 的元素&#xff0c;并返回移除后数组的新长度。 不要使用额外的数组空间&#xff0c;你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出…

【Linux进程】进程控制(中) {进程等待:等待的必要性,进程等待的方法wait,waitpid,退出状态status,waitpid非阻塞等待}

三、进程等待 3.1 进程等待必要性 之前讲过&#xff0c;子进程退出&#xff0c;父进程如果不管不顾&#xff0c;就可能造成‘僵尸进程’的问题&#xff0c;进而造成内存泄漏。另外&#xff0c;进程一旦变成僵尸状态&#xff0c;那就刀枪不入&#xff0c;“杀人不眨眼”的kill …

easyexcel 将对应列的格式改为数字或者文本格式

1.在easyexcel 导出excel时 需要将某个列的格式指定&#xff0c;例如指定为数字格式 例如 需要把单元格格式设置为数值&#xff0c;并且保留小数点后三位&#xff0c;按道理来说应该是这样子设置 /** * test&#xff0c; 最终导出值 */ ExcelProperty(value "test")…

01 linux基础(1)

环境安装 解压&#xff0c;从vmware打开虚拟机。 设置密码&#xff1a;1 打开终端&#xff1a;ctrlaltt linux介绍 Linux的发展 1&#xff09;1969年&#xff0c;由kenthompson在AT&T贝尔实验室实现的。使用的是汇编语言。 2&#xff09;1970年&#xff0c;KenThompson…

【Linux后端服务器开发】HTTPS协议

目录 一、加密算法 二、中间人攻击 三、CA认证 一、加密算法 HTTPS协议是什么&#xff1f;HTTPS协议也是一个应用层协议&#xff0c;是在HTTP协议的基础上引入了一个加密层。 HTTP协议内容是按照文本的方式明文传输的&#xff0c;这就导致在传输过程中出现一些被篡改的情况…

Java使用FFmpeg实现mp4转m3u8

Java使用FFmpeg实现mp4转m3u8 前言FFmpegM3U8 一、需求及思路分析二、安装FFmpeg1.windows下安装FFmpeg2.linux下安装FFmpegUbuntuCentOS 三、代码实现1.引入依赖2.修改配置文件3.工具类4.Controlle调用5.Url转换MultipartFile的工具类 四、播放测试1.html2.nginx配置3.效果展示…

QT读写ini文件

QT读写ini文件 源代码文件结构mysql.hmysql.cppmain.cpp my.ini文件截图运行截图QSettings 最开始的需求是使用qt读取不同电脑上的MySQL的my.ini文件实现在不同电脑上也可以成功登录数据库&#xff0c;不用担心密码和用户名不同的问题 到之后发现其实并没有什么用&#xff0c;因…

一文搞定Java IO流,输入流、输出流、字符流、缓冲流,附详细代码示例

目录 一、InputStream1、FileInputStream的代码示例2、ByteArrayInputStream的代码示例3、PipedInputStream的代码示例 二、 OutputStream1、FileOutputStream代码示例2、ByteArrayOutputStream代码示例&#xff1a;3、PipedOutputStream代码示例&#xff1a; 三、字符输入流Re…

7.25 作业 QT

手动实现登录框&#xff1a; widget.cpp: #include "widget.h" #include <QMovie> Widget::Widget(QWidget *parent): QWidget(parent) {//设置尺寸this->resize(800,600); //设置宽高//设置固定尺寸this->setFixedSize(800,600);//窗口标题操作qDebu…

C数据结构与算法——顺序栈 应用(C语言纯享版 迷宫)

实验任务 (1) 掌握顺序栈及其C语言的表示&#xff1b; (2) 掌握入栈、出栈等基本算法的实现&#xff1b; (3) 掌握顺序栈的基本应用&#xff08;求解迷宫通路&#xff09;。 实验内容 使用C语言实现顺序栈的类型定义与算法函数&#xff1b;编写main()函数并根据需要修改、补…

❓“如何创业?互联网创业又该如何入手?

&#x1f31f;5大创业建议&#xff0c;让你轻松入门&#xff01; 作为一名互联网创业者&#xff0c;我想分享一下我的创业经验。下面是我的五个建议&#xff0c;希望对你有所帮助&#xff01; &#x1f31f;了解市场需求 在创业之前&#xff0c;了解市场需求非常重要。你需要研…

【Rust日报】2023-07-24 使用 Rust 重写的InfluxDB 3.0

使用 Rust 重写的InfluxDB 3.0 InfluxDB 是一个开源的、分布式的时序数据库&#xff0c;用于存储和分析时间序列数据, 于 2013 年由 Brian Bondy 和 Nicholas Zakhariev 创立。 InfluxDB 最初是用 Go 语言编写的。 2018 年&#xff0c;InfluxData 决定将 InfluxDB 重写为 Rust …