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

 Python has won the favor of many developers with its concise code. This has prompted more developers to use Python to develop new modules, thus forming a virtuous cycle. Python can achieve many interesting operations with shorter codes. 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 2D barcode. The common QR code is QR Code. QR stands for Quick Response. It is a very popular encoding method on mobile devices in recent years. Generating a QR code is also very simple. In Python, we can generate QR codes 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 

After the installation is complete we can start writing code:

import qrcode

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

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

Let's install the MyQR module first

pip install  myqr
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()

In addition, MyQR also supports dynamic pictures.

2. Generate word cloud

Word cloud, also called text cloud, is a visually prominent presentation of "keywords" that appear frequently in text data. The rendering of the keywords forms a cloud-like color picture, so that you can understand the main points of the text data at a glance. express meaning.

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

Install 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()

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

picture

Read these 10 lines of code:

  • Lines 1 to 3 import the drawing library matplotlib, the word cloud generation library wordcloud and jieba's word segmentation library 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.

  • Lines 5 to 6, use jieba for word segmentation, and separate the results of word segmentation with spaces;

  • 7 lines, generate a word cloud from the text after the word segmentation;

  • Lines 8 to 10, use pyplot to display the word cloud map.

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

3. Batch cutout

The realization of image cutout requires the use of Baidu Feipiao's deep learning tool paddlepaddle. We need to install two modules to quickly implement batch cutout. The first one is PaddlePaddle:

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

There is also a paddlehub model library:

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

Next, we only need 5 lines of code to implement 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})    # 抠图

4. Text emotion recognition

In front of paddlepaddle, natural language processing has become very simple. To realize text emotion recognition, we also need to install PaddlePaddle and Paddlehub. For specific installation, please refer to Part 3. Then there is 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)

The result of recognition is a list of dictionaries:

{'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'

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

Here we also use PaddlePaddle products. We installed PaddlePaddle and Paddlehub according to the above steps, and then started writing code:

import paddlehub as hub
# 加载模型
module = hub.Module(name='pyramidbox_lite_mobile_mask')
# 图片列表
image_list = ['face.jpg']
# 获取图片字典
input_dict = {'image':image_list}
# 检测是否带了口罩
module.face_detection(data=input_dict)

After executing the above program, 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. Taking pynput as an example, we need to install the module first:

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

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)

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秒

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

Seven, recognize the text in the picture

We can use Tesseract to identify text in pictures. It is very simple to implement in Python, but downloading files and configuring environment variables in the early stage is 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)

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

8. Simple games

Getting started with a few small examples feels productive.

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 + 次)

Guess the small case in front of practice hands

Guess you like

Origin blog.csdn.net/m0_59595915/article/details/132619448