相信许多刷编程题的小伙伴在刷题过程中已经感受到编程题的输出要求是多种多样的,有些输出格式看着就已经头皮发麻了,比如下面这个...

面对这些较为复杂的输出情况,我们就需要掌握各种各样的输出方法与输出格式了,下面就对常用的输出方式与方法做一些总结。
(1).直接输出(适用于无特殊输出要求的情况)
print(1)
#输出:1
print('very good!')
#输出:very good!
print('A')
#输出:A
print([1,2,3,4,5])
#输出:[1,2,3,4,5]
print({1:'a',2:'b',3:'c'})
#输出:{1:'a',2:'b',3:'c'}
(2).加星号拆包(更加适用于一行打印出数组元素)
x = [1,2,3,4,5]
print(*x)
#输出:1 2 3 4 5
y = {1:'a',2:'b',3:'c',4:'d'}
print(*y)
#输出:1 2 3 4
(3).加入%进行格式化控制(适用于保留几位小数、进制、对齐、科学计数法等较为复杂的情况)
首先我们先了解一下格式符号
以下为标准格式化格式符
| 格式符 | 表示 |
| %s | 字符串 |
| %d | 十进制整数 |
| %f | 浮点型 |
| %c | 字符型 |
| %u | 无符号十进制整数 |
| %o | 八进制 |
| %x | 十六进制 |
| %e | 科学计数法 |
还有一些常用的格式符
| 格式符 | 表示 |
| %.2f | 保留两位小数 |
| %04d | 输出前面4个字符空间补零 |
| %4d | 右对齐前面留出4个字符空间 |
| %-4d | 左对齐并占用4个字符空间 |
介绍一些常见输出场景
x = 123
print('%d'%x)
#输出:123
print('这有一个整数%d'%666)
#输出:这有一个整数666
print('%.2f'%3.141592)
#输出:3.14
print('%e'%14332231433223)
#输出:1.433223e+13
print('%04d'%99)
#输出:000099
print('%9s'%'hahaha')
#输出: hahaha(注意左侧有多个空格)
format进制格式化字符
| 格式符 | 表示 |
| {:s} | 字符串 |
| {:d} | 十进制整数 |
| {:f} | 浮点型 |
| {:c} | 字符型 |
| {:u} | 无符号十进制整数 |
| {:o} | 八进制 |
| {:x} | 十六进制 |
| {:e} | 科学计数法 |
以下是format常用格式化字符
| 格式符 | 表示 |
| {:.2f} | 保留两位小数 |
| {:+.2f} | 保留两位小数并携带正负号 |
| {:0>2d} | 左侧补零,整体占两个字符 |
| {:0<2d} | 右侧补零,整体占两个字符 |
| {:*<4d} | 右侧补星号,整体占4个字符 |
| {:5d} | 右对齐,整体占5个字符 |
| {:<5d} | 左对齐,整体占5个字符 |
| {:^5d} | 居中对齐,整体占5个字符 |
| {:.2e} | 科学计数法并保留两位小数 |
| {:,} | 以逗号分割的数字 |
介绍一下format常见输出场景:
x = 123
print('{}'.format(x))
#输出:123
print('hello!{}'.format('World'))
#输出:hello!World
print('{}'.format(['1','2','3','4','5']))
#输出:['1','2','3','4','5']
print('{}->{}->{}'.format(1,2,3))
#输出:1->2->3
print('{2}->{0}->{1}'.format(1,2,3))
#输出:3->1->2
print('The Number is {}'.format(666))
#输出:The Number is 666
print('{:.2f}'.format(3.245))
#输出:3.25
print('{:0>4d}'.format(12))
#输出:0012
print('{:>8s}'.format('abc'))
#输出: abc(注意abc前面有空格)
print('{:<8d}'.format(999))
#输出:999 (注意999后面有空格)
print('{:.2e}'.format(1234554321))
#输出:1.23e+09
另外,print()+format()的搭配还可以这样写
x = 123
print(f'The Number is {x:d}')
#输出:The Number is 123
y = 3.1415
print(f'PI is {y:.2f} ...')
#输出:3.14
z = [1,3,5,7,9]
print(f'{z[0]:d} {z}')
#输出:1 [1, 3, 5, 7, 9]
(1).打印一行数组
x = [1,2,3,4,5,6,7]
print(' '.join(map(str,x)))
#输出:1 2 3 4 5 6 7
(2).打印一行以任意字符分割的数组
x = [1,2,3,4,5,6,7]
print('*'.join(map(str,x)))
#输出:1*2*3*4*5*6*7
(3).打印多行数组/二维数组-两种方法
x = [[1,2,3],[4,5,6],[7,8,9]]
for i in x:
print(*i)
#输出:
1 2 3
4 5 6
7 8 9
或者
x = [[1,2,3],[4,5,6],[7,8,9]]
for i in x:
print(' '.join(map(str,i)))
#输出:
1 2 3
4 5 6
7 8 9
(4).打印一行且不换行
print("no enter",end="")
(5).将两个不同维度的二维数组并排打印
'''
二维数组A: 二维数组B:
1 2 3 4 1 3 5
5 6 7 8 2 4 6
6 7 8 9 7 8 9
3 2 1
'''
#定义两个二维数组
a = [[1,2,3,4],[5,6,7,8],[6,7,8,9]]
b = [[1,3,5],[2,4,6],[7,8,9],[3,2,1]]
#定义组合输出所需列表
out_list = []
sum_len = len(a[0])+len(b[0])+1
while a!=[] or b!=[]:
if a!=[]: #取数组a一行
out_list+=a.pop(0)+[' ']
if b!=[]: #取数组b一行
out_list+=b.pop(0)
if len(out_list)<sum_len and a == []: #取剩下的数组一行
out_list = list(' '*(sum_len-len(out_list)))+out_list
print(*out_list) #输出两个二维数组一行的合并内容
out_list = []
'''
输出:
1 2 3 4 1 3 5
5 6 7 8 2 4 6
6 7 8 9 7 8 9
3 2 1
'''
像上面这种情况需要较多数据处理的过程的输出还有很多,比如打印乘法口诀表、打印沙漏等等
面对这些情况,解决问题的关键就在于输出数据的预处理了,而不是输出方法与方式的选择
比如在文章开头提到的这个题,题目来自PAT乙级1109
题目链接: PAT乙级1109

Python题解:
import sys
alpha_dict = {}
out_list = []
start = 'abcdefghijklmnopqrstuvwxyz'
str_1 = ''
if_has_pt = False
def printLine(in_str,dict_in,num): '''打印整行字母矩阵,矩阵的1行等于输出7行'''
out_line = []
for i in range(0,7):
for j in in_str:
try:
out_line.append(dict_in[j][i])
except:
continue
if num==1 and i==6:
print(" ".join(out_line),end="")
else:
print(" ".join(out_line))
out_line = []
for x in range(0,26): '''这个循环负责读入题目给出的输入'''
alpha_dict[start[x]] = [sys.stdin.readline().replace('\n','') for x in range(7)]
in_2 = sys.stdin.readline().replace('\n','')
for y in range(0,len(in_2)): '''这个循环用于根据输出条件判断是否要输出'''
if in_2[y].isupper():
str_1 = str_1 + in_2[y]
if_has_pt = False
if ((in_2[y].isupper()==False and if_has_pt==False
and str_1!='') or (y+1==len(in_2) and str_1!='')):
str_1 = str_1.lower()
out_list.append(str_1) '''满足条件的输出行存入列表中'''
str_1 = ''
if_has_pt = True
for z in range(0,len(out_list)): '''迭代打印整行字母矩阵块'''
if z+1==len(out_list):
printLine(out_list[z],alpha_dict,1)
else:
printLine(out_list[z],alpha_dict,0)
print()
这个输出方法是python的标准化输出,需要我们导入sys模块才能使用
import sys
x = '123123'
sys.stdout.write(x)
#输出:123123
stdout.write与print的不同是,print打印时默认换行,而stdout.write不换行
还有一点就是stdout.write只支持字符串类型的输出,所以感觉还是print好用
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案
我正在使用puppet为ruby程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这