[Pythonクラスノート] Pythonデータ処理(1)

Pythonデータ処理(1)

データ照合


ファイルの文字数を数える

ファイルはday.txt次のとおりです。
ここに画像の説明を挿入

#统计这个文件中day的个数
import re     #re是匹配字符串的模块,该模块中提供的很多功能是基于正则表达式实现的
f=open(r'文件路径 day.txt')
source=f.read()
print(source)
f.close()
r='day'
s=len(re.findall(r,source)) 
#在字符串中找到所匹配的所有子串,并返回一个列表,如果没有找到匹配的,则返回空列表。
print(s)

出力:

have a good day,have a good day,have a good day
3

文字列を置き換えて別のテキストファイルに保存する

# 把day.txt 中的day全部换为"day2",并把结果保存day2.txt中
import re
f1 = open(r'文件路径 day.txt')
f2 = open(r'文件路径 day2.txt','w')
for s in f1.readlines():
    f2.write(s.replace('day','day2'))
f1.close()
f2.close()

day2.txt示されているように:
ここに画像の説明を挿入


画像処理

PIL:Python Imaging Library画像処理ライブラリ。
PILには9つの異なるモードがあります。すなわち、1、L、P、RGB、RGBA、CMYK、YCbCr、I、Fです。一般的に使用される:
  • モード「1」は、黒または白のバイナリイメージです。各ピクセルは8ビットで表され、黒は0、白は255です。
  • モード "L"はグレーの画像で、各ピクセルは8ビットで表され、0は黒、255は白、その他の数値は異なるグレーレベルを示します。
  • モード「P」は8ビットのカラー画像で、各ピクセルは8ビットで表され、対応するカラー値はカラーパレットに従って照会されます。
  • モード "RGBA"は32ビットのカラー画像で、各ピクセルは32ビットで表され、そのうち24ビットは赤、緑、青の3つのチャネルを表し、8ビットは透明チャネルであるアルファチャネルを表します。
  • モード「CMYK」は32ビットのカラー画像であり、各ピクセルは32ビットで表され、4色モードを印刷する。
  • モード「YCbCr」は24ビットのカラー画像であり、各ピクセルは24ビットで表されます。
#将模式为"RGB"的图像转换为模式"1"
from PIL import Image
lena =Image.open(r"图片路径 qs.jpg")
lena.show()
print(lena.mode)
print(lena.getpixel((0,0)))
lena_1 = lena.convert("1")
print(lena_1.mode)
print(lena_1.size)
print(lena_1.getpixel((0,0)))
print(lena_1.getpixel((10,10)))
lena_1.show()

出力:

RGB
(255, 255, 255)
1
(510, 723)
255
255

元の画像:
ここに画像の説明を挿入
変換後:
ここに画像の説明を挿入


画像の回転

#图像的旋转
from PIL import Image
from pylab import *
im=Image.open(r"C:\Users\图片路径 qs.jpg")
out = im.resize((128, 128))     
out.show()
out = im.rotate(45)   
out.show()
out = im.transpose(Image.FLIP_LEFT_RIGHT)  #左右对换。
out.show()
out = im.transpose(Image.FLIP_TOP_BOTTOM)  #上下对换
out.show()
out = im.transpose(Image.ROTATE_90)   
out.show()

回転した写真を出力する

メイクしてください


画像の灰色化

#图像的灰化
from PIL import Image
from pylab import *
im=Image.open(r"图片路径 qs.jpg")
im.show()
#from PIL import Image
#from pylab import *
im = array(Image.open(r"图片路径 qs.jpg").convert('L'))
im2 = 255 - im 
im3 = (100.0/255) * im + 100   
im4 = 255.0 * (im/255.0)**2
figure(figsize=(16,8))
subplot(221)
title('f(x) = x')
gray()
imshow(im) 
subplot(222)
title('f(x) = 255 - x')
imshow(im2)
subplot(223)
title('f(x) = (100/255)*x + 100')
imshow(im3)
subplot(224)
title('f(x) =255 *(x/255)^2')
imshow(im4)
print(int(im.min()),int(im.max()))
print(int(im2.min()),int(im2.max()))
print(int(im3.min()),int(im3.max()))
print(int(im4.min()),int(im4.max()))
show()

出力:

0 255
0 255
100 200
0 255

ここに画像の説明を挿入


ピクセルを調整する

from PIL import Image
im=Image.open(r"C:\Users\午后阳光\Desktop\qs.jpg")
im.show()
w,h=im.size
print(w)
print(h)
out = im.resize((800,800),Image.ANTIALIAS)
out.show()
w1,h1=out.size
print(w1)
print(h1)

出力:

510
723
800
800

ここに画像の説明を挿入


18件の元の記事を公開 Likes6 1859を訪問

おすすめ

転載: blog.csdn.net/qq_43479203/article/details/105363798
おすすめ