百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

干货分享:如何用Python写一个小程序,生成字符图

liuian 2025-01-20 14:46 19 浏览

文 | JiawuLab ,原创作品。

前两天,我用Python写了个小程序,主要功能是将一张图输入后,程序会输出字符图,然后将字符图保存在txt文本中,效果图如下:

昨天将这个小程序的一些技术要点发布到了微头条中,这里将技术要点贴出来:

1、首先对图片进行黑白处理、对比度处理,这样可以去除很多的噪点,
2、然后使用了getpixel()方法,该方法可以得到当前位置图片的颜色值,
3、再通过颜色值的判断,就能将不同的颜色值处理成对应的符号,这里我处理为“#“ ,
4、最后将所有颜色值处理后得到的符号信息,保存为txt文件。

如上图,微头条获得很多朋友的关注,短短一天的时间,阅读数就突破了1万2,特别高兴,我会继续加油的。

本篇文章将创造这个小程序中的思考与实践过程分享给大家,也期待大家能理解造轮子过程的乐趣。


一、为什么会写这个小程序?

说来话并不长,在学习群中,有位可爱的同学,分享了一张某程序员的注释图,里面写了篇打油诗,还配了张字符图,就是下面这张图:

看得出作者非常的有才气,只是好像言语之中透露了某些信息,哈哈?

而我看到的就是下面这尊字符串佛像,触发了自己写个小程序将图片转换为字符图的念头,这就是我写这个小程序的初衷。


二、思考过程

我初步的想法是:

1、在网上找一张图,然后将图片转化为黑白图,
2、利用PIL库中的方法,获取图片上的颜色数值,
3、将黑色和白色的部分,分别用不同的字符串代替

最后打印出来就可以了,而且技术实现也很简单。


三、实践过程

首先,我在网上找到了一张很有feel的图片,如下图:

技术实现过程如下:

1、convert('1'),用来转化为黑白图,
2、使用PIL库中的getpixel()方法获取颜色数值,此时只有“0”、“1”,
3、使用"for"循环,遍历整张图片,将“0”、“1”分别用“ ”,“#”代替,得到字符串并打印

运行代码,发现图片太大,显示不出来,如下图中红色箭头指的部分,只是图片中最左上角的一点:

于是改代码,做出下面两点修改

1、利用“resize”函数,将图片尺寸更改为固定宽度“150”,高度使用运算公式获取,代码为:“im.resize((150, int(im.size[1]/im.size[0]*150)))”
2、将字符串,输出到“txt”文本中,方便运行查看

运行后,打开保存的txt文件,发现全糊了,根本看不清是什么。

如上图,完全看不出是什么,于是我用“im.show()”方法,查看了黑白图片是什么样的:

从这里就能看出来,原来生成的黑白图片的噪点太多,除了狮子是糊的,左下角也都是噪点。

所以在原图转为黑白图片前,需要做一下图片处理,这里就会用到"ImageEnhance"方法,进行对比度等图片处理,比如此处用到的对比度图片代码为“ImageEnhance.Contrast(im).enhance(2.0)”

这样就好很多了,图片上基本上没有太多噪点了,狮子整体也非常明显,但是有点太亮了,所以再次使用亮度处理,代码为“ImageEnhance.Brightness(im).enhance(0.9)”

现在黑白图片整体看上去,就比较不错了,可以进行字符图的生成。

在前面生成的字符图中,我发现一个问题,周边设置为空白,不是很好看,所以修改技术点为:

将“0”、“1”分别用“ ”,“#”代替——改为将“0”、“1”分别用“#”,“ ”代替

只是将字符串替换了一下,最后得到的字符图为:

一只王者气派的狮子字符图就做好了,是不是很像那么回事。

在图片处理过程中,其实做了很多动作,包括选择图片处理效果时,使用了很多的方法,最后确定下来使用对比度和亮度的结合。

而对比度和亮度处理中的参数,也需要不断的进行优化,最后才能呈现出比较漂亮的结果。

如上图,放上原图和字符图的对比效果,字符图会有一些纵向拉伸的效果,这是因为txt文件的行间距的问题。换个角度来看,这就是天然的瘦身效果哦。


四、复杂背景图片的演示

狮子这张图是背景比较简单的图片,那么背景复杂的效果又会如何呢?(永远要有一颗折腾的心?)

我在网上找到一张背景复杂的图片,如下图:

然后运行程序,看看会得到什么呢?(我想应该美女应该会变瘦哦,哈哈?)

果然,生成的字符图中,美女变得又高又瘦,我感觉比原图更好看啦?

我又找了另一张图,生成的效果,还不错吧。


五、代码分享

最后,我将代码分享给大家,整个代码不到20行,特别简单:


需要提醒的是:有些图片生成的字符图会不太好看,你自己可以根据需要调整参数或是图片处理方法。


六、总结

本期文章中,我将创作一个小程序的整个过程分享出来,其中包含前期的思考过程,功能实践过程,以及功能调优过程。

我认为最重要的一点就是前期的思考过程,通过对需求的分析,能够让我们找到合适的技术实现要点,从而让整个实践过程可控,能更顺利的实现功能。

希望你喜欢本期的分享,欢迎大家在评论区讨论、转发,或者顺手点个赞。谢谢。

相关推荐

【常识】如何优化Windows 7

优化Windows7可以让这个经典系统运行更流畅,特别是在老旧硬件上。以下是经过整理的实用优化方案,分为基础优化和进阶优化两部分:一、基础优化(适合所有用户)1.关闭不必要的视觉效果右键计算机...

系统优化!Windows 11/10 必做的十个优化配置

以下是为Windows10/11用户整理的10个必做优化配置,涵盖性能提升、隐私保护和系统精简等方面,操作安全且无需第三方工具:1.禁用不必要的开机启动项操作路径:`Ctrl+S...

最好用音频剪辑的软件,使用方法?

QVE音频剪辑是一款简单实用的软件,功能丰富,可编辑全格式音频。支持音频转换、合并、淡入淡出、变速、音量调节等,无时长限制,用户可自由剪辑。剪辑后文件音质无损,支持多格式转换,便于存储与跨设备播放,满...

Vue2 开发总踩坑?这 8 个实战技巧让代码秒变丝滑

前端开发的小伙伴们,在和Vue2打交道的日子里,是不是总被各种奇奇怪怪的问题搞得头大?数据不响应、组件传值混乱、页面加载慢……别慌!今天带来8个超实用的Vue2实战技巧,每一个都能直击痛...

Motion for Vue:为Vue量身定制的强大动画库

在前端开发中,动画效果是提升用户体验的重要手段。Vue生态系统中虽然有许多动画库,但真正能做到高性能、易用且功能丰富的并不多。今天,我们要介绍的是MotionforVue(motion-v),...

CSS view():JavaScript 滚动动画的终结

前言CSSview()方法可能会标志着JavaScript在制作滚动动画方面的衰落。如何用5行CSS代码取代50多行繁琐的JavaScript,彻底改变网页动画每次和UI/U...

「大数据」 hive入门

前言最近会介入数据中台项目,所以会推出一系列的跟大数据相关的组件博客与文档。Hive这个大数据组件自从Hadoop诞生之日起,便作为Hadoop生态体系(HDFS、MR/YARN、HIVE、HBASE...

青铜时代的终结:对奖牌架构的反思

作者|AdamBellemare译者|王强策划|Tina要点运维和分析用例无法可靠地访问相关、完整和可信赖的数据。需要一种新的数据处理方法。虽然多跳架构已经存在了几十年,并且可以对...

解析IBM SQL-on-Hadoop的优化思路

对于BigSQL的优化,您需要注意以下六个方面:1.平衡的物理设计在进行集群的物理设计需要考虑数据节点的配置要一致,避免某个数据节点性能短板而影响整体性能。而对于管理节点,它虽然不保存业务数据,但作...

交易型数据湖 - Apache Iceberg、Apache Hudi和Delta Lake的比较

图片由作者提供简介构建数据湖最重要的决定之一是选择数据的存储格式,因为它可以大大影响系统的性能、可用性和兼容性。通过仔细考虑数据存储的格式,我们可以增强数据湖的功能和性能。有几种不同的选择,每一种都有...

深入解析全新 AWS S3 Tables:重塑数据湖仓架构

在AWSre:Invent2024大会中,AWS发布了AmazonS3Tables:一项专为可扩展存储和管理结构化数据而设计的解决方案,基于ApacheIceberg开放表格...

Apache DataFusion查询引擎简介

简介DataFusion是一个查询引擎,其本身不具备存储数据的能力。正因为不依赖底层存储的格式,使其成为了一个灵活可扩展的查询引擎。它原生支持了查询CSV,Parquet,Avro,Json等存储格式...

大数据Hadoop之——Flink Table API 和 SQL(单机Kafka)

一、TableAPI和FlinkSQL是什么TableAPI和SQL集成在同一套API中。这套API的核心概念是Table,用作查询的输入和输出,这套API都是批处理和...

比较前 3 名Schema管理工具

关注留言点赞,带你了解最流行的软件开发知识与最新科技行业趋势。在本文中,读者将了解三种顶级schema管理工具,如AWSGlue、ConfluentSchemaRegistry和Memph...

大数据技术之Flume

第1章概述1.1Flume定义Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构,灵活简单。1.2Flume的优点1.可以和...