网易首页 > 网易号 > 正文 申请入驻

Python实用脚本/算法集合, 附源代码下载

0
分享至

学习编程、学习Python最好的方式就是练习,哪怕是新手,只要不断地敲代码输出,肯定会有神效。

Python的练手项目很多,特别是Github上,建议不管新手、老司机都去看看。

这里推荐给大家两个Github上练习的项目, 算法仓库-algorithms脚本仓库-Python master

后文会有相应源代码集打包下载,给需要的小伙伴。

algorithms算法仓库

首先来看看算法仓库-algorithms。

这里面集合众多核心算法的Python实现,比如排序、图计算、回溯、队列、流计算、堆、搜索、压缩等等。

该仓库支持第三方库安装,在python中进行调用,非常方便。

首先使用pip进行安装:

pip3 install algorithms

然后导入相关模块进行调用,比如sort模块里的merge_sort归并排序算法。

from algorithms.sort import merge_sort

if __name__ == "__main__":
my_list = [1, 8, 3, 5, 6]
my_list = merge_sort(my_list)
print(my_list)

个人感觉这个仓库里的算法很齐全,适合做练习,小伙伴们可以试试。

所有算法脚本 已经打包好,获取步骤如下:

1,点击下方公众号 数据STUDIO 名片

2,关注 数据STUDIO后,在消息后台回复 b

▲点击关注「数据STUDIO」回复b

另外,@公众号:数据STUDIO 还为大家整理和筛选了大量火爆全网的Python数据科学学习资料,全部资料按需自助免费获取!直接点击链接:


Python脚本仓库

另外还有一个很好的练手项目,脚本仓库-Python master。

这个项目收集了作者平时工作用到的几千个实用小脚本,作者虽然不是程序员,但他这种用代码解决问题的习惯会极大的提升效率,也会迸发出更多的创新思维。

我觉得这样的代码每个人都可以写出来,只要慢慢积累多练习就可以。

举一个简单的例子,作者写了一个创建二维码的脚本,可以自动将url转化为二维码。

import pyqrcode
import png
from pyqrcode import QRCode

# Text which is to be converted to QR code
print("Enter text to convert")
s = input(": ")
# Name of QR code png file
print("Enter image name to save")
n = input(": ")
# Adding extension as .pnf
d = n + ".png"
# Creating QR code
url = pyqrcode.create(s)
# Saving QR code as a png file
url.show()
url.png(d, scale=6)

除此之外,该仓库中还有很多这样实用的脚本文件。

所有算法脚本 已经打包好,获取步骤如下:

1,点击下方公众号 数据STUDIO 名片

2,关注 数据STUDIO后,在消息后台回复 d

▲点击关注「数据STUDIO」回复d

另外,@公众号:数据STUDIO 还为大家整理和筛选了大量火爆全网的Python数据科学学习资料,全部资料按需自助免费获取!直接点击链接:


接下来,展示一些更多的代码案例,供大家参考。

从图片中截取文字 # extract text from a img and its coordinates using the pytesseract module
import cv2
import pytesseract

# You need to add tesseract binary dependency to system variable for this to work

img = cv2.imread("img.png")
# We need to convert the img into RGB format
img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

hI, wI, k = img.shape
print(pytesseract.image_to_string(img))
boxes = pytesseract.image_to_boxes(img)
for b in boxes.splitlines():
b = b.split(" ")
x, y, w, h = int(b[1]), int(b[2]), int(b[3]), int(b[4])
cv2.rectangle(img, (x, hI - y), (w, hI - h), (0, 0, 255), 0.2)

cv2.imshow("img", img)
cv2.waitKey(0)
判断闰年 def is_leap(year):
leap = False
if year % 4 == 0:
leap = True
if year % 100 == 0:
leap = False
if year % 400 == 0:
leap = True
return leap

year = int(input("Enter the year here: "))
print(is_leap(year))
打印图片分辨率 def jpeg_res(filename):
""""This function prints the resolution of the jpeg image file passed into it"""

# open image for reading in binary mode
with open(filename,'rb') as img_file:

# height of image (in 2 bytes) is at 164th position
img_file.seek(163)

# read the 2 bytes
a = img_file.read(2)

# calculate height
height = (a[0] << 8) + a[1]

# next 2 bytes is width
a = img_file.read(2)

# calculate width
width = (a[0] << 8) + a[1]

print("The resolution of the image is",width,"x",height)

jpeg_res("img1.jpg")
排序算法-桶排序 def bucket_sort(arr):
''' Bucket Sort
Complexity: O(n^2)
The complexity is dominated by nextSort
'''
# The number of buckets and make buckets
num_buckets = len(arr)
buckets = [[] for bucket in range(num_buckets)]
# Assign values into bucket_sort
for value in arr:
index = value * num_buckets // (max(arr) + 1)
buckets[index].append(value)
# Sort
sorted_list = []
for i in range(num_buckets):
sorted_list.extend(next_sort(buckets[i]))
return sorted_list

def next_sort(arr):
# We will use insertion sort here.
for i in range(1, len(arr)):
j = i - 1
key = arr[i]
while arr[j] > key and j >= 0:
arr[j+1] = arr[j]
j = j - 1
arr[j + 1] = key
return arr
机器学习-最近邻插值法 import math

def distance(x,y):
"""[summary]
HELPER-FUNCTION
calculates the (eulidean) distance between vector x and y.

Arguments:
x {[tuple]} -- [vector]
y {[tuple]} -- [vector]
"""
assert len(x) == len(y), "The vector must have same length"
result = ()
sum = 0
for i in range(len(x)):
result += (x[i] -y[i],)
for component in result:
sum += component**2
return math.sqrt(sum)

def nearest_neighbor(x, tSet):
"""[summary]
Implements the nearest neighbor algorithm

Arguments:
x {[tupel]} -- [vector]
tSet {[dict]} -- [training set]

Returns:
[type] -- [result of the AND-function]
"""
assert isinstance(x, tuple) and isinstance(tSet, dict)
current_key = ()
min_d = float('inf')
for key in tSet:
d = distance(x, key)
if d < min_d:
min_d = d
current_key = key
return tSet[current_key]
符串解码编码 # Implement the encode and decode methods.

def encode(strs):
"""Encodes a list of strings to a single string.
:type strs: List[str]
:rtype: str
"""
res = ''
for string in strs.split():
res += str(len(string)) + ":" + string
return res

def decode(s):
"""Decodes a single string to a list of strings.
:type s: str
:rtype: List[str]
"""
strs = []
i = 0
while i < len(s):
index = s.find(":", i)
size = int(s[i:index])
strs.append(s[index+1: index+1+size])
i = index+1+size
return strs
直方分布 def get_histogram(input_list: list) -> dict:
"""
Get histogram representation
:param input_list: list with different and unordered values
:return histogram: dict with histogram of input_list
"""
# Create dict to store histogram
histogram = {}
# For each list value, add one to the respective histogram dict position
for i in input_list:
histogram[i] = histogram.get(i, 0) + 1
return histogram

个人感觉这两个仓库里的算法和脚本很齐全,适合做练习,小伙伴们可以试试。

所有算法脚本 已经打包好,获取步骤如下:

1,点击下方公众号 数据STUDIO 名片

2,关注 数据STUDIO后,在消息后台回复 b 或者 d

▲点击关注「数据STUDIO」回复b 或者 d

另外,@公众号:数据STUDIO 还为大家整理和筛选了大量火爆全网的Python数据科学学习资料,全部资料按需自助免费获取!直接点击链接:


特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
高考分数633!她是娱乐圈唯一考进清华的童星,颜值和美貌并存

高考分数633!她是娱乐圈唯一考进清华的童星,颜值和美貌并存

大果小果妈妈
2024-06-16 19:08:59
火速再就业!广东替补内线加盟山西男篮年薪不低于50万杜锋送祝福

火速再就业!广东替补内线加盟山西男篮年薪不低于50万杜锋送祝福

小鬼头体育
2024-06-19 19:14:39
新能源车渗透率都过50%了,为什么没见过专修新能源车的修理厂?

新能源车渗透率都过50%了,为什么没见过专修新能源车的修理厂?

音乐时光的娱乐
2024-06-18 01:27:18
“早立秋冷飕飕,晚立秋热死牛”,2024年立秋是早是晚?答案来了

“早立秋冷飕飕,晚立秋热死牛”,2024年立秋是早是晚?答案来了

农夫也疯狂
2024-06-19 11:34:20
紧急提醒:千万别吃!上海竟有商户公开售卖?很容易混淆,多地发布预警:小心中毒

紧急提醒:千万别吃!上海竟有商户公开售卖?很容易混淆,多地发布预警:小心中毒

上观新闻
2024-06-19 22:35:48
退休后除了养老金,还有额外这两笔钱,一共好几十万,太开心了!

退休后除了养老金,还有额外这两笔钱,一共好几十万,太开心了!

社保小达人
2024-05-14 10:14:43
爸爸晒女儿结婚10年的变化,照片令人心疼,前后对比太明显

爸爸晒女儿结婚10年的变化,照片令人心疼,前后对比太明显

布谷妈妈
2024-06-18 21:30:54
男生收到4070TiS后崩溃爆哭 女生:显卡威力这么大?

男生收到4070TiS后崩溃爆哭 女生:显卡威力这么大?

手机中国
2024-06-18 15:00:15
曾任市委书记的他 主动向组织交代问题

曾任市委书记的他 主动向组织交代问题

鲁中晨报
2024-06-19 16:03:14
安徽打响中科大保卫战?有望落地苏州的中科大国际校区再起变数

安徽打响中科大保卫战?有望落地苏州的中科大国际校区再起变数

小李子体育
2024-06-19 13:18:55
抗日神剧八路军的伙食,不是海鲜就是法国菜,主打的就是一个上流

抗日神剧八路军的伙食,不是海鲜就是法国菜,主打的就是一个上流

附允历史观
2024-06-19 16:45:10
权威消息!中国C919大飞机或将很快取得欧盟(EASA)适航证

权威消息!中国C919大飞机或将很快取得欧盟(EASA)适航证

嘿哥哥科技
2024-06-19 19:37:55
空警-500要落后了?国产新预警机初露真容,为何没用运-20平台?

空警-500要落后了?国产新预警机初露真容,为何没用运-20平台?

笔墨V
2024-06-20 01:35:03
又被庾澄庆的鞋震撼到了!时隔13年再次断舍离,堆成山的经典款!

又被庾澄庆的鞋震撼到了!时隔13年再次断舍离,堆成山的经典款!

娱小小新
2024-06-19 11:52:52
2-2绝平!欧洲杯大冷:世界第10出线告急,286万人口小国创造历史

2-2绝平!欧洲杯大冷:世界第10出线告急,286万人口小国创造历史

侃球熊弟
2024-06-19 21:29:58
乐道L60到店,前宾利设计师设计,大Model Y一圈,起步555km续航

乐道L60到店,前宾利设计师设计,大Model Y一圈,起步555km续航

闻车品百魅
2024-06-18 18:01:17
未来三年,最好的投资,是守家

未来三年,最好的投资,是守家

洞见
2024-06-17 21:24:44
小S又曝大S劲爆旧料:去奢侈品购物被店员无视,一怒之下买了两个

小S又曝大S劲爆旧料:去奢侈品购物被店员无视,一怒之下买了两个

小徐讲八卦
2024-06-19 07:30:47
普京专机借道中国领空,连访朝鲜越南,俄罗斯急需一场翻身仗

普京专机借道中国领空,连访朝鲜越南,俄罗斯急需一场翻身仗

刘庆彬
2024-06-19 08:25:02
新晋小生爱擦边女?陈晓陈妍希离婚实锤?鞠婧祎被封杀?王安宇撕戏?姨太问答

新晋小生爱擦边女?陈晓陈妍希离婚实锤?鞠婧祎被封杀?王安宇撕戏?姨太问答

毒舌扒姨太
2024-06-19 22:11:47
2024-06-20 05:00:49
Python小二
Python小二
人生苦短,我用Python!
389文章数 1899关注度
往期回顾 全部

科技要闻

618观察:谁为高强度的低价竞争买单?

头条要闻

俄罗斯总统普京抵达越南进行国事访问

头条要闻

俄罗斯总统普京抵达越南进行国事访问

体育要闻

欧洲杯最大的混子,非他莫属

娱乐要闻

黄一鸣“杀疯了” 直播间卖大葱养孩子

财经要闻

深化科创板改革 证监会发布八条措施

汽车要闻

双肾格栅变化大/内饰焕新 新一代宝马X3官图发布

态度原创

艺术
家居
旅游
公开课
军事航空

艺术要闻

穿越时空的艺术:《马可·波罗》AI沉浸影片探索人类文明

家居要闻

自然开放 实现灵动可变空间

旅游要闻

遭遇极端高温天气导致希腊多名游客死亡

公开课

近视只是视力差?小心并发症

军事要闻

以色列涉嫌在加沙使用重型炸弹 或多次违反战争法

无障碍浏览 进入关怀版