What cool things can be done with ten lines of Python code?

WBOY
Release: 2023-05-04 19:58:05
forward
1245 people have browsed it

Let’s take a look at what interesting functions we can achieve with no more than 10 lines of code.

1. Generate QR code

QR code is also called two-dimensional barcode. The common two-dimensional code is QR Code. The full name of QR is Quick Response. It is a super popular mobile device in recent years. A popular coding method, and generating a QR code is also very simple. In Python, we can generate a QR code through the MyQR module. To generate a QR code, we only need 2 lines of code. We first install the MyQR module. Here we choose the domestic source download:

pip install qrcode
Copy after login

After the installation is completed, we can start writing code:

import qrcode text = input(输入文字或URL:) # 设置URL必须添加http:// img =qrcode.make(text) img.save() #保存图片至本地目录,可以设定路径 img.show()
Copy after login

After we execute the code, it will be generated under the project A QR code. Of course, we can also enrich the QR code:

We first install the MyQR module

pip installmyqr def gakki_code(): version, level, qr_name = myqr.run( words=https://520mg.com/it/#/main/2, # 可以是字符串,也可以是网址(前面要加http(s)://) version=1,# 设置容错率为最高 level='H', # 控制纠错水平,范围是L、M、Q、H,从左到右依次升高 picture=gakki.gif, # 将二维码和图片合成 colorized=True,# 彩色二维码 contrast=1.0, # 用以调节图片的对比度,1.0 表示原始图片,更小的值表示更低对比度,更大反之。默认为1.0 brightness=1.0, # 用来调节图片的亮度,其余用法和取值同上 save_name=gakki_code.gif, # 保存文件的名字,格式可以是jpg,png,bmp,gif save_dir=os.getcwd()# 控制位置 ) gakki_code()
Copy after login

In addition, MyQR also supports dynamic pictures.

2. Generate word cloud

Word cloud is also called word cloud. It is a visual prominent presentation of "keywords" that appear more frequently in text data and forms key words. The rendering of words forms a cloud-like color picture, so that the main meaning of the text data can be understood at a glance.

But as an old coder, I still like to use code to generate my own word cloud. Is it complicated? Does it take a long time? Many texts have introduced various methods, but in fact it only takes 10 lines. Just python code.

Install the necessary libraries first

pip install wordcloud pip install jieba pip install matplotlib import matplotlib.pyplot as plt from wordcloud import WordCloud import jieba text_from_file_with_apath = open('/Users/hecom/23tips.txt').read() wordlist_after_jieba = jieba.cut(text_from_file_with_apath, cut_all = True) wl_space_split =.join(wordlist_after_jieba) my_wordcloud = WordCloud().generate(wl_space_split) plt.imshow(my_wordcloud) plt.axis(off) plt.show()
Copy after login

That’s it, the generated word cloud looks like this:

What cool things can be done with ten lines of Python code?

Read these 10 lines of code:

  • Lines 1 to 3 import the drawing library matplotlib, the word cloud generation library wordcloud and the word segmentation library of jieba respectively;
  • Line 4 is to read a local file. The text used in the code is "Two or three things about R&D management in the eyes of Lao Cao" in this public account.
  • Line 5~6, use jieba to segment the words, and separate the results of the word segmentation with spaces;
  • Line 7, generate a word cloud for the text after word segmentation;
  • In lines 8 to 10, use pyplot to display the word cloud diagram.

This is one of the reasons why I like python, it is simple and clear.

3. Batch cutout

The implementation of cutout requires the help of Baidu Feipiao's deep learning tool paddlepaddle. We need to install two modules to quickly implement batch cutout. Chapter 1 One is PaddlePaddle:

python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/simple
Copy after login

and the other is paddlehub model library:

pip install -i https://mirror.baidu.com/pypi/simple paddlehub
Copy after login

Next we only need 5 lines of code You can achieve batch cutout:

import os, paddlehub as hub humanseg = hub.Module(name='deeplabv3p_xception65_humanseg')# 加载模型 path = 'D:/CodeField/Workplace/PythonWorkplace/GrapImage/'# 文件目录 files = [path + i for i in os.listdir(path)]# 获取文件列表 results = humanseg.segmentation(data={'image':files})# 抠图
Copy after login

4. Text emotion recognition

In front of paddlepaddle, natural language processing It also becomes very simple. To realize text emotion recognition, we also need to install PaddlePaddle and Paddlehub. For specific installation, please refer to Part 3. Then comes our code part:

import paddlehub as hub senta = hub.Module(name='senta_lstm')# 加载模型 sentence = [# 准备要识别的语句 '你真美', '你真丑', '我好难过', '我不开心', '这个游戏好好玩', '什么垃圾游戏', ] results = senta.sentiment_classify(data={text:sentence})# 情绪识别 # 输出识别结果 for result in results: print(result)
Copy after login

The recognition result is a dictionary list:

{'text': '你真美', 'sentiment_label': 1, 'sentiment_key': 'positive', 'positive_probs': 0.9602, 'negative_probs': 0.0398} {'text': '你真丑', 'sentiment_label': 0, 'sentiment_key': 'negative', 'positive_probs': 0.0033, 'negative_probs': 0.9967} {'text': '我好难过', 'sentiment_label': 1, 'sentiment_key': 'positive', 'positive_probs': 0.5324, 'negative_probs': 0.4676} {'text': '我不开心', 'sentiment_label': 0, 'sentiment_key': 'negative', 'positive_probs': 0.1936, 'negative_probs': 0.8064} {'text': '这个游戏好好玩', 'sentiment_label': 1, 'sentiment_key': 'positive', 'positive_probs': 0.9933, 'negative_probs': 0.0067} {'text': '什么垃圾游戏', 'sentiment_label': 0, 'sentiment_key': 'negative', 'positive_probs': 0.0108, 'negative_probs': 0.9892}
Copy after login

The sentiment_key field contains sentiment information. For detailed analysis, please see Python natural language processing only requires 5 lines of code.

5. Identify whether you are wearing a mask

This is also a product using PaddlePaddle. We installed PaddlePaddle and Paddlehub according to the above steps, and then started writing code:

import paddlehub as hub# Load model module = hub.Module(name='pyramidbox_lite_mobile_mask')# Image list image_list = ['face.jpg']# Get the image dictionary input_dict = {'image':image_list}# Check whether it has Mask module.face_detection(data=input_dict)

After executing the above procedure, the detection_result folder will be generated under the project, and the recognition results will be in it.

6. Simple information bombing

There are many ways to control input devices in Python. We can use the win32 or pynput module. We can achieve the effect of information bombing through simple loop operations. Here, taking pynput as an example, we need to install the module first:

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ pynput
Copy after login

Before writing the code, we need to manually obtain the coordinates of the input box:

from pynput import mouse # 创建一个鼠标 m_mouse = mouse.Controller() # 输出鼠标位置 print(m_mouse.position)
Copy after login

There may be a more efficient way, but I won't.

After obtaining it, we can record the coordinates and do not move the message window. Then we execute the following code and switch the window to the message page:

import time from pynput import mouse, keyboard time.sleep(5) m_mouse = mouse.Controller()# 创建一个鼠标 m_keyboard = keyboard.Controller()# 创建一个键盘 m_mouse.position = (850, 670) # 将鼠标移动到指定位置 m_mouse.click(mouse.Button.left) # 点击鼠标左键 while(True): m_keyboard.type('你好')# 打字 m_keyboard.press(keyboard.Key.enter)# 按下enter m_keyboard.release(keyboard.Key.enter)# 松开enter time.sleep(0.5)# 等待 0.5秒
Copy after login

I admit, this is more than 10 lines of code, and it is not high-end.

7. Identify text in pictures

We can use Tesseract to identify text in pictures. It is very simple to implement in Python, but it requires downloading files and configuring environment variables in the early stage. It’s a bit cumbersome, so this article only shows the code:

import pytesseract from PIL import Image img = Image.open('text.jpg') text = pytesseract.image_to_string(img) print(text)
Copy after login

where text is the recognized text. If you are not satisfied with the accuracy, you can also use Baidu's universal text interface.

八、简单的小游戏

从一些小例子入门感觉效率很高。

import random print(1-100数字猜谜游戏!) num = random.randint(1,100) guess =guess i = 0 while guess != num: i += 1 guess = int(input(请输入你猜的数字:)) if guess == num: print(恭喜,你猜对了!) elif guess < num: print(你猜的数小了...) else: print(你猜的数大了...) print(你总共猜了%d %i + 次)
Copy after login

猜数小案例当着练练手


The above is the detailed content of What cool things can be done with ten lines of Python code?. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:51cto.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!