Python小技巧练习分享
1.反转数字
问题场景: 把数字 789 转换为 987。
典型的数字翻转问题。
解决思路: 将数字的百位十位个位拆解出来,就解开了
编码如下:
def reverse_number(number):
baiwei = int(number/100)
shiwei = int(number%100/10)
gewei = int(number%10)
return gewei*100+shiwei*10+baiwei
new_number = reverse_number(789)
print(new_number)
2.类的说明文档
问题场景: 给新创建的类添加说明文档
解决思路: 在类名下使用三引号即可添加说明文档,使用 类名,__doc__
可调用该文档
编码如下:
class My_Class(object):
"""你好"""
print(My_Class.__doc__)
3.设置 Python 文件的编码
问题场景: Python 文件设置默认编码。
解决思路: Python 脚本文件默认是使用 UTF-8 编码格式进行编码的,一般无需指定编码,但我们也可自行设置编码,Python2 代码文件一般都带该行注释。 设置方式是使用一行注释,要求格式需满足下述正则表达式。
编码如下:
coding[=:]\s*([-\w.]+)
声明位置在 Python 文件的第一行或者第二行,注意 :
或 =
前没有空格。
例如下述代码:
# -*- coding:utf-8 -*-
也可以使用大写:
# -*- coding:UTF-8 -*-
4.旋转字符串
问题场景: 一个字符串,一个数字,完成如下操作
- 字符串为
abcde
,数字为 3,则输出cdeab
; - 字符串为
abcde
,数字为 1,则输出eabcd
; - 字符串为
abcde
,数字为 0,则输出abcde
; - ……
解决思路: 一个字符串切片运用的问题。
编码如下:
def reverse_str(my_str,offset):
# 如果数字为 0,顺序默认不变
if offset ==0:
return my_str
left = my_str[:len(my_str)-offset]
right = my_str[len(my_str)-offset:]
return right + left
5.实现控制台滚动条
问题场景:在控制台输出滚动条。
解决思路:使用字符串格式化进行实现,例如用 >
表示进展,用 /
表示未完成的进展,使用 ljust()
方法返回一个原字符串左对齐,并使用填充字符(默认空格)填充至指定长度的新字符串。
编码如下: 逐步实现
# 打印一行 >>>
progress_str = ">" * 100
print(progress_str)
填充一部分 >
,再填充另一部分 /
。
# 打印一行 >>>
progress_str = ">"*20
# 填充50个 -
progress_str = progress_str.ljust(100,'/')
print(progress_str)
实现循环操作:
import time
for i in range(0, 11):
time.sleep(0.3)
current = i/10
# 进度条
progress_str = '{0:s}{1:.0%}'.format(
(int(current*10)*'>').ljust(10, '/'), current)
print(progress_str)
为了让其在一行出现,可以修改代码为如下格式,注意最后一行代码。
import time
for i in range(0, 11):
time.sleep(0.3)
current = i/10
# 进度条
progress_str = '{0:s}{1:.0%}'.format(
(int(current*10)*'>').ljust(10, '/'), current)
print(f'\r{progress_str}',end='')
6.print 函数直接写入文件
问题场景 :如果不希望将 print
函数输出的内容,打印到控制台,而是直接输入到文件中,该如何操作?
解决思路 :print()
函数有一个参数叫做 file
,用它就行。
编码如下:
file = open('runtime.log', 'a+', encoding='utf-8')
print('测试日志', file=file)
7.合并 2 个列表
问题场景 合并 2 个列表,并要求合并之后的列表有顺序。 例如 my_list1 = [1,2,3]
, my_list2 = [1,3,5]
,合并之后是 my_list = [1,1,2,3,3,5]
解决思路 先合并 2 个列表,然后判断其各个元素大小,判断的时候使用冒泡排序即可完成任务。 编码如下
def merge(l1, l2):
my_list = l1 + l2
n = len(my_list)
for i in range(n):
for j in range(0, n - i - 1):
if my_list[j] > my_list[j + 1]:
my_list[j], my_list[j + 1] = my_list[j + 1], my_list[j]
print(my_list)
if __name__ == '__main__':
my_list1 = [4, 2, 6]
my_list2 = [1, 3]
merge(my_list1, my_list2)
到此这篇关于Python小技巧练习分享的文章就介绍到这了,更多相关Python练习内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341