python之 print()函数的输出学问(函数解析以及格式化输出)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 前言:内容比较简单基础,但是很有用,方便。本篇主要针对print()函数的输出进行说明,所以不会构建长篇大论的大标题小标题。简洁明了!你是怎样用python的输出语句呢?是这样吗?下面展示一些 内联代码片。print("Hello World")1其实print函数的用途不止这些,输出也并不是只有有这样单调那么具体的根源,我们就看这个函数完整的形式喽

前言:内容比较简单基础,但是很有用,方便。本篇主要针对print()函数的输出进行说明,所以不会构建长篇大论的大标题小标题。简洁明了!


你是怎样用python的输出语句呢?

是这样吗?

下面展示一些 内联代码片。


print("Hello World")


其实print函数的用途不止这些,输出也并不是只有有这样单调

那么具体的根源,我们就看这个函数完整的形式喽!


print(*values, sep=' ', end='\n', file=sys.stdout, flush=False)


对各个参数进行分析


下面展示一些 内联代码片。


values :值,代表了你要输出的内容,比如你的hello world
sep : 打印出值得分割方式(具体看后面得代码演示)
end: 代表结束得方式(默认是'\n'结束,所以print()函数输出内容会自动换行)
file : 指定了输出内容到哪里,默认是到控制台,所以我们一般很自然就在控制台
看到我们的输出内容。
flush:代表了刷新方式(具体的我们在后面代码中说明)


1:对sep参数的解析


#values就不做过多的说明了,我们直接从step开始
print("你好","世界",sep="--");#前面的逗号分隔决定了你好和世界是两个字符串,指定sep的值是采用了什么符号对两个字符串进行分割。


输出结果如下:



还有一点说明,看代码


print("你好"+"世界",sep=",")#与上面的对比输出区分


输出结果如下:



可见并没有对你好世界进行分割,这样的原因是以加号进行的前面,先拼接为一个字符串,sep指定的分割是区别两个字符串的。不明白?看下面


print("你好"+"世界","hello",sep=",")


输出结果如下



2:对end参数的解析


#我们先这样输出
print("十年生死两茫茫")#end参数一般会默认\n,就是换行的意思,改变end参数的值观察输出效果
print("不思量,自难忘")


可以看到这边的print()是自动换行的


输出结果:



#然后我们这样输出
print("十年生死两茫茫",end=",")#end参数一般会默认\n,就是换行的意思,改变end参数的值观察输出效果
print("不思量,自难忘")


输出结果:



3:对file参数的解析


通常我们的输出会直接输出到终端,那么我现在要把我想要输出的内容直接输出到我的文件中,怎么做?看代码。


建立一个文件作为输出目标


我们现在要输出内容到这里面,看代码


File = open("D:\\python\\pydoc\\jgdabc_666\\1.txt",'w',encoding="utf-8")#这边指定编码,以防乱码
print("蒋光道要么变强,要么灭亡!",file=File)
File.close()


运行结果:


4flush参数的解析


看代码


#我们还是对文件进行一下输入内容
我采用了一种对文件操作的方式
while True : 
    File = open("D:\\python\\pydoc\\jgdabc_666\\1.txt",'w',encoding="utf-8")#这边指定编码,以防乱码
    print("蒋光道要么变强,要么灭亡!",file=File,flush=False)
    input()


说明,我这边采用了一个无限循环的方式,也就是对文件进行反复写入,我可以在文件中看到效果的动态变化(如果我们没有加入input的话,可以看到文件写入文件内容的动态变化效果)


这边说明input的作用


我这边其实想演示的就是flush刷新的作用,当你的文件没有关闭的话,flush参数指定为flase并不会写入文件,而是先写入缓存区,所以其实文件中暂且不会出现内容。我这边开始没有让文件关闭来着,但是我发现程序运行太快,自动执行完程序,文件就自动关闭了,那么我就先让程序处于一个等待我输入的状态,那么文件也就不会因为程序自动执行完而自动关闭。所以文件没有关闭的情况下,内容是不会写入的。



我的程序还在等待我输入,但是写入操作已经执行完毕了,但是因为flush指定参数的原因,内容没有写入文件,而是先写入了缓冲区。


while True : 
    File = open("D:\\python\\pydoc\\jgdabc_666\\1.txt",'w',encoding="utf-8")#这边指定编码,以防乱码
    print("蒋光道要么变强,要么灭亡!",file=File,flush=False)
    #input()


可以看到input()函数注释后就会写入了,即使是while死循环也阻止不了文件每次执行到底部的自动关闭,然后文件又自动打开,反复进行。while循环对全局是死循环,但是内部是一直在执行。



注意:这一点我是按照个人的理解进行的,如果读者觉得有问题可以提出或者指正。谢谢!


4格式化输出format占位格式


这边我们进行整体输出对比即可,然后我会对疑点进行说明


{} 与format() 函数进行配合,起到占位的作用,具体格式以及输出样子看代码


print("my name is{},and i love {}".format('jgdabc','programing'))#格式化输出,{}里面不带参数
print("{}is {}".format('jgdabc','蒋光道'))
print("{1} is {0}".format("jgdabc","蒋光道"))#{}指定参数,调换填入数据的前后顺序
print("{0} is {1} is {0}".format("jgdabc",'蒋光道'))#对输出的控制
print("{a} {b} {c}".format(a="hello",b="world",c="everyone"))#指定输出
print("{:5s} is {:>5s}".format("hello","world"))# 取位对齐
print("{:^10s} is {:^10s}".format("jgdabc","蒋光道")) #中间取位对齐
print("{0} is {0:1.2f}".format(1.231)) # 取数值的位数
print("{:.1f} and {:.2f}".format(1.23,1.32))
print("{0} is {0:b} ".format(2)) # 对数取进制
print("{0} is {0:g}".format(11111111))# g格式,数值太大,会以数的带e格式输出
print("{0} is {0:%}".format(1.21)) # 以百分格式输出


好,我们看输出结果



格式化占位f开头占位

看代码


name = "jgdabc"
age = 22
print(f'my name is {name}') # f格格式占位输出
print(f"my age is {age:.2f}")#f格式输出以及格式控制


输出结果 :



对print()函数的解析就到这里,我们常用的就是这些,当然还有其它的输出函数形式。如果对print()函数的格式话输出又疑问的话欢迎留言。


相关文章
|
1天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
1天前
|
存储 索引 Python
Python入门:6.深入解析Python中的序列
在 Python 中,**序列**是一种有序的数据结构,广泛应用于数据存储、操作和处理。序列的一个显著特点是支持通过**索引**访问数据。常见的序列类型包括字符串(`str`)、列表(`list`)和元组(`tuple`)。这些序列各有特点,既可以存储简单的字符,也可以存储复杂的对象。 为了帮助初学者掌握 Python 中的序列操作,本文将围绕**字符串**、**列表**和**元组**这三种序列类型,详细介绍其定义、常用方法和具体示例。
Python入门:6.深入解析Python中的序列
|
1天前
|
存储 Linux iOS开发
Python入门:2.注释与变量的全面解析
在学习Python编程的过程中,注释和变量是必须掌握的两个基础概念。注释帮助我们理解代码的意图,而变量则是用于存储和操作数据的核心工具。熟练掌握这两者,不仅能提高代码的可读性和维护性,还能为后续学习复杂编程概念打下坚实的基础。
Python入门:2.注释与变量的全面解析
|
7天前
|
监控 算法 安全
内网桌面监控软件深度解析:基于 Python 实现的 K-Means 算法研究
内网桌面监控软件通过实时监测员工操作,保障企业信息安全并提升效率。本文深入探讨K-Means聚类算法在该软件中的应用,解析其原理与实现。K-Means通过迭代更新簇中心,将数据划分为K个簇类,适用于行为分析、异常检测、资源优化及安全威胁识别等场景。文中提供了Python代码示例,展示如何实现K-Means算法,并模拟内网监控数据进行聚类分析。
28 10
|
25天前
|
存储 算法 安全
控制局域网上网软件之 Python 字典树算法解析
控制局域网上网软件在现代网络管理中至关重要,用于控制设备的上网行为和访问权限。本文聚焦于字典树(Trie Tree)算法的应用,详细阐述其原理、优势及实现。通过字典树,软件能高效进行关键词匹配和过滤,提升系统性能。文中还提供了Python代码示例,展示了字典树在网址过滤和关键词屏蔽中的具体应用,为局域网的安全和管理提供有力支持。
50 17
|
28天前
|
运维 Shell 数据库
Python执行Shell命令并获取结果:深入解析与实战
通过以上内容,开发者可以在实际项目中灵活应用Python执行Shell命令,实现各种自动化任务,提高开发和运维效率。
56 20
|
1月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
16 0
|
1月前
|
自然语言处理 数据处理 索引
mindspeed-llm源码解析(一)preprocess_data
mindspeed-llm是昇腾模型套件代码仓,原来叫"modelLink"。这篇文章带大家阅读一下数据处理脚本preprocess_data.py(基于1.0.0分支),数据处理是模型训练的第一步,经常会用到。
53 0
|
2月前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
|
2月前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象结构型模式比类结构型模式具有更大的灵活性。 结构型模式分为以下 7 种: • 代理模式 • 适配器模式 • 装饰者模式 • 桥接模式 • 外观模式 • 组合模式 • 享元模式
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析

推荐镜像

更多