Python3输入输出

Python两种输出值的方式,表达式语句和print()函数。

第三种方式是使用文件对象的write()方法,标准输出文件可以用sys.stdout的引用。

如果你希望输出的形式更加多样,可以使用str.fomat()函数来格式化输出值。

如果你希望将输出的值转化成字符串,可以使用repr()和str()函数来实现。

str():函数返回一个用户易读的表达式

repr():产生一个解释器易读的表达形式。

 

 

 

这里有两种方式输出一个平方和立方的表:

 

 

 

 

 

 

注意:在第一个例子种,每个列间的空格由print添加。

这个例子展示了字符串对象的rjust()方法,它可以将字符串靠右,并在左边填充空格。

还有类似的方法,如ljust()和center()。这些方法并不会写任何东西,他们仅仅返回新的字符串。

还有一个zfill(),它会在数字的左边填充0,如下所示:

str.format()的基本用法如下:

 

print(’{}网址: “{}!“’.format(‘菜鸟教程’,‘www.runoob.com’))

菜鸟教程网址:”www.runoob.com”

括号及其里面的字符(俗称格式化字符)将会被format()中的参数替换。

在括号中的数字用于指向传入对象在format()中的位置

 

 

 

如果format()中使用了关键字参数,那么他们的值会指向使用该名字的参数。

 

 

 

位置和关键字参数可以任意结合:

 

 

 

!a(使用ascii()),!s(使用str())和!r(使用repr())可以用于格式化某个值之前对其进行转化:

 

 

 

可选项: 和格式标识符可以跟着字段名。这允许对值进行更好的格式化。

 

 

在 : 后传入一个整数,可以保证该域至少有这么多宽度。用于美化表格时很有用:

 

 

旧式字符串格式化:

%操作符也可以实现字符串格式化它将左边参数作为类是sprintf()式的格式化字符串,而将右边的代入,然后返回格式化后的字符串。

 

 

因为str.format()比较新的缘故,大多数python仍然使用%操作符,但是因为这种旧时的格式化最总会从该语言中移除,应该更多的使用str.format()

 

读取键盘输入

python提供了input()内置函数从标准输入读入一行文本,默认的标准输入是键盘。

input可以接受一个Python表达式作为输入,然后从运算结果返回。

 

 

读和写文件

open()将会返回一个file文件,基本语法格式如下:

open(filename,mode)

filename:包含了你要访问的文件名的字符串值。

mode:决定了打开文件的模式:只读,写入,追加等。

 

不同模式打开文件的文件完全列表:

模式

描述

r

以只读方式打开文件。文件的指针将会放在文件的开头,这是默认模式

rb

以二进制格式打开一个文件用于只读,文件指针将会放在文件的开头

r+

打开一个文件用于读写。文件指针将会放在文件的开头

rb+

以二进制格式打开一个文件用于读写,文件指针将会放在文件的开头

w

打开一个文件只用于写入如果该文件

wb

以二进制格式打开一个文件用于读写,如果该文件已存在则打开文件,并且从头开始编辑,即原有内容会被删除,如果该文件不存在则创建新文件。

a

打开一个文件用于追加,如果该文件已存在,文件指针将会放在文件的结尾。也就是说新的内容会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

ab

以二进制格式打开一个文件用于追加如果该文件已存在,文件指针将会放在文件的结尾。也就是说新的内容将会被写入到已有内容之后如果该文件不存在,创建新文件进行读写。

a+

打开一个文件用于读写如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式,如果该文件不存在,创建新文件用于读写。

ab+

以为禁止格式打开一个文件用于追加,如果该文件已存在。如果文件已存在,文件指针会放在文件结尾,如果该文件不存在,创建新文件用于读写。

 

 

模式

r

r+

w

w+

a

a+

+

+

 

+

 

+

 

+

+

+

+

+

创建

 

 

+

+

+

+

覆盖

 

 

+

+

 

 

指针在开始

+

 

+

+

 

 

指针在结尾

 

+

 

 

+

+

以下实例将字符串传入到foo.txt

 

 

 

文件对象的方法

f.read()

为了读取一个文件的内容,调用f.read(size),这将读取一定数目的数据,然后作为字符串或者字节对象返回。

size是一个可选的数字类型的参数。当size被忽略了或为负时,那么该文件的所有内容都将被读取并且返回。

 

 

f.readline()

该函数会从一个文件中读取单独的一行换行符为’\n’。f.readline()如果返回一个空字符串,说明已经读取到最后一行。

 

 

f.readlines():

该函数会返回文件所包含的所有行。

如果参数可选参数sizehint,则读取指定长度的字节,并且将这些字节按行分隔。

 

 

另一种方式迭代一个文件对象然后读取每行。

 

 

这个方法虽然很简单,但是没有提供一个很好的控制,因为两者的处理机制不同

 

f.write()

f.write(string)将string写入到文件中,然后返回写入的字符数。

 

 

如果要写入的东西不是字符串的话,那么需要先将其转换成字符串。

 

 

f.tell()

该函数返回文件对象当前所处的位置,它是从文件开头开始算起的字节数

 

f.seek()

如果要该改变文件当前的位置,可以使用f.seek(offset,from_what)函数。

from_what的值,如果是0表示开头,如果是1表示当前位置,2表示文件的结尾。

seek(x,0):从起始位置即文件首行首字符开始移动x个字符。

seek(x,1):表示从当前位置往后移动x个字符。

seek(-x,2):表示从文件的结尾往前移动x个字符。

 

from_what值为默认为0,即文件开头

 

 

f.close()

在文本文件中(那些打开文件的模式下没有b的),只会想相对于文件起始位置进行定位。

当你处理完一个文件后,调用f.close()来关闭文件并释放系统资源,如果尝试再调用该文件,则会抛出异常。

当处理一个文件对象时,使用with关键字也是非常好的方法。在结束时他会帮助你正确的关闭文件,并且写起来也要比try-finally语句块要简短。

 

 

格式化输出:

1.整数的输出

 

 

分别输出八进制十进制和十六进制。

2.浮点数输出

%f保留小数点后面六位有效数字float

%e保留小数点后六位有效数字

%g在保证六位有效数字前提下,使用小数方法,否则就使用科学记数法

 

 

1)默认保留6位小数

2)娶一位小数1.1

3)默认六位小数,用科学记数法

4)去三位小数,用科学记数法

5)默认六位有效数字

6)取七位有效数字

7)取2位有效数字

 

3.字符串输出

%s字符串输出string

%10s 占位符10位

%-10s 左对齐占位符10位

%.2s 截取2位字符串

%10.2s 10位占位符,截取两位字符串

 

 

1) 字符串输出hello world

2) 右对齐,取20位,不够则补位

3) 左对齐,取20位,不够则部位

4) 取两位he

5) 右对齐取两位

6) 左对齐取两位

转载于:https://www.cnblogs.com/wanghao-boke/p/11510431.html

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

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

相关文章

Python3正则表达式

正则表达式是一个特殊的字符序列,他能帮助你方便的检查一个字符串是否与某种模式匹配。re.match函数 re.match尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回一个none。 函数语法: re.match(pat…

signal()函数

函数原型 void (*signal(int sig,void(*func)(int)))(int); 指定使用sig指定的信号编号处理信号的方法。参数func指定程序可以处理信号的三种方式之一: l 默认处理(SIG_DFL): 信号由该特定信号的默认动作处理l 忽略信号(SIG_IGN&a…

【C++学习之路】第一章——C++核心方法总论

1 C核心方法总论 1.1 核心思想 通过实际项目来学习编程,更高效掌握编程规则,以及明白各种语法规则的实际应用。 实验思想:任何C的参考资料都不可能覆盖你遇到的所有问题,这个时候,最好的办法就是,编辑代…

【学会如何学习系列】从婴儿到大学——学习的本质从未改变过

从婴儿到大学——学习的本质从未改变过 从我们出生一直到现在,其实,学习的本质从来都没有改变过,并且,婴儿时期的我们,是学习能力最强的时候,随着我们不断长大,外界的诱惑越来越多,…

【Verilog HDL学习之路】第二章 Verilog HDL的设计方法学——层次建模

2 Verilog HDL的设计方法学——层次建模 重要的思想: 在语文教学中,应该先掌握核心方法论,再用正确的方法论去做题目,这样能够逐渐加深对于方法论的理解,做题的速度和准确率也会越来越高。在Verilog HDL中&#xff0c…

【Verilog HDL】第四章 模块的端口连接规则——污水处理模型

先放上连接规则的简图,再详细解释 1. 构建模型——污水处理之流水模型 我们先将上述结构构件一个简单模型,以帮助我们理解。 污水:输入数据净水:输出数据双向数据暂不讨论,取输入和输出的交集即可污水处理厂&…

【Verilog HDL】从逻辑电路图到门级建模——人工翻译的方法论

从左到右,从上到下 先搞定缓冲/非门,再写与/或门 1. 实例解读 先以四选一数据选择器进行说明 对于数字逻辑的部分不再说明,直接进行逻辑电路图到Verilog门级建模的人工翻译过程的描述。 1.1 端口和线网分析 确定输入/输出端口 输入端口 …

【Verilog HDL】语句的并发执行

1. 实践得到的启发 先从一个简单的现象得出结论,Verilog语句是并发执行的! 同时,这也是**$monitor系统任务为全局有效**的一个重要支持因素,如果没有并发,它是完不成这项功能的实现的。 众所周知,高级语…

【数字逻辑】第四章 组合逻辑电路:端口设计 端口拓展的方法

1. 端口设计的方法 1.1 数据选择器 以四选一数据选择器为例,需要的不同接口类型为 输入端口 数据输入端口地址输入端口使能端(控制与拓展) 输出端口 数据输出端口 2. 端口拓展的方法——层次建模思想 2.0 两个拓展方向 2.0.1 “数组型…

【Verilog HDL】第三章 reg和net及其一组类型的区别——充分运用实验思维

0 确定问题的讨论层级与范围 本文讨论的层次是 数字逻辑与Verilog HDL语言 讨论的范围是: 数据存储而不是讨论逻辑 1 线网类型 1.1 wire类型 这个暂时没什么好说的,一般常用的就是wire类型,需要注意的是: 默认是标量&…

【C/C++ 汇编语言 Verilog】越界截断——数据越界问题的多角度分析

0 前言 0.1 讨论层级和范围 讨论层级 计算机底层:硬件层次与汇编指令层次信息与二进制位 讨论范围 信息的存储与运算在汇编语言与Verilog HDL中的联系与区别事实上,数据越界截断问题,在计算机体系的任何层次,都可能发生&#xf…

【VS C++ 2010】查看内存的方法详解

1 示例代码 对于以下代码&#xff1a; int main() {int a 100010001000;int b 100;cout << "a " << a << " " << &a << endl;cout << "b " << b << " " << &b…

【汇编语言】上机实验 win7/8/10 64位系统 进入32位DOS模式 实现dubug/edit/masm/link功能

1 软件下载和安装 下载并安装DOSBox软件&#xff0c;注意&#xff0c;不要装在C盘上&#xff0c;装在其他盘上 【备注】软件直接百度搜索即可下载Debug.exe文件 【备注】百度搜索“Debug 64位 下载” 对于下载后得到的debug.exe文件 将这个文件拷贝到磁盘根目录下&#xff0c…

【数字逻辑 Verilog】全面剖析数据选择器——从基础到拓展,从理论到设计的实现,从表面到本质

0 前言 0.1 使用环境 EDA工具&#xff1a;Vivado 2017.4硬件描述语言&#xff1a;Verilog HDL 0.2 涉及知识 数字逻辑Verilog 1 基础模块&#xff1a;一位四选一数据选择器 1.1 设计部分&#xff1a;层次建模 1.1.1 需求分析 设计一个一位的四选一数据选择器&#xff0…

【计算机网络】手动配置hosts文件解决使用GitHub和Coursera网站加载慢/卡的问题

目录0 前言1 打开hosts1.1 以管理员身份运行记事本1.2 打开hosts2 找到实际地址2.1 打开cmd2.2 找到网址3 替换地址3.1 修改hosts文件3.2 刷新4 后续内容的完善0 前言 本文是针对纯小白读者&#xff0c;没有涉及到任何的专业知识&#xff0c;你只需要按照步骤操作即可。 同时…

【汇编语言】镜像迁移能力之一通百通——由代码段和CS:IP的原理,掌握一类寄存器的使用

0 前言 你应该知道8086CPU的物理地址形成方式及其原理&#xff0c;才能完成本文的学习。 1 内存的分段 对于内存&#xff0c;人们人为地将其划分为一段一段的&#xff0c;比如代码段和数据段等&#xff0c;特别注意&#xff0c;这是人为划分的结果&#xff0c;方面人类使用&…

【计算机组成原理 数字逻辑 Verilog】32位加法器的实现:支持整数的加减运算

目录0 前言0.1 使用环境0.2 知识点0.3 注意事项1 建模&#xff1a;1位加法器1.1 构建基础模型1.1.1 一位加法器1.1.1.1 科技黑箱&#xff1a;外部端口与功能1.1.1.2 揭秘黑箱&#xff1a;内部结构与模块1.1.2 从顶层模块提取低层模块&#xff1a;取反功能选择器1.1.2.1 科技黑箱…

【Verilog HDL】门级描述 / 数据流描述 / 行为级描述——通过四选一多路选择器,实现对于不同层级描述方式的整体性认知

目录0 前言1 输出端口的设计1.1 门级描述和数据流描述1.2 行为级描述2 三种描述方式的整体架构2.1 门级描述2.2 数据流描述2.3 行为级描述2.4 补充&#xff1a;独立的语句2.5 小结3 理解三种描述方式的本质3.1 门级描述3.2 数据流描述3.3 行为级描述4 理解不同抽象层级描述方式…

【汇编语言】汇编实验IDE(集成开发环境):RadASM的安装和使用说明

0 前言 本文适合8086CPU的指令集。 对于重要的专业基础课程&#xff0c;汇编语言&#xff0c;做实验是必不可少的&#xff0c;但是由于汇编语言本身的缺陷&#xff0c;现代计算机并不能直接运行汇编语言程序&#xff0c;因此&#xff0c;一般老师会要求我们 使用虚拟机&…

System V IPC之信号灯

信号灯也叫信号量 用于进程/线程同步或互斥的机制 信号灯的类型 1.Posix 无名信号灯 2.Posix 有名信号灯 3.System V 信号灯 信号灯的含义 计数信号灯&#xff08;1和2都是&#xff09; System V信号灯是一个或多个计数信号灯的集合&#xff08;可操作集合中的多个信号灯&…