from PIL import Image imload = Image.open(r'C:\Users\Administrator\Desktop\测试\test.jpg') im = imload.convert("RGB") width, height = im.size demo = open('rgd.txt', 'a') for y in range(height): for x in range(width): rgd = im.getpixel((x, y)) rgd = str(rgd) demo.write(rgd[1:-1]+"\t") demo.write("\n") demo.close() 返回的TXT在Excel中打开为一行如何解决
时间: 2023-11-27 17:52:49 浏览: 64
你可以在写入文件时,每次写入一个像素的 RGB 值后,不写入换行符,而是写入一个制表符 '\t'。然后在每行末尾写入一个换行符 '\n',这样就可以保证每个像素的 RGB 值都被正确地写入到一个单元格中了。
修改后的代码如下:
```python
from PIL import Image
imload = Image.open(r'C:\Users\Administrator\Desktop\测试\test.jpg')
im = imload.convert("RGB")
width, height = im.size
with open('rgd.txt', 'a') as demo:
for y in range(height):
for x in range(width):
rgd = im.getpixel((x, y))
rgd = str(rgd)
demo.write(rgd[1:-1] + "\t")
demo.write("\n")
```
这里使用了 `with open()` 语句来打开文件,以确保文件在使用完毕后能够被正确关闭。同时,我们还将文件写入操作放在了 `with open()` 语句内部,这样可以在写入完成后自动关闭文件。
相关问题
import pytesseract from PIL import Image image = Image.open('test.png') text = pytesseract.image_to_string(image) print(text)
当你导入`pytesseract`并从`PIL`模块导入`Image`时,你可以使用以下代码来读取图像文件(如'test.png')并提取文本内容:
```python
import pytesseract
from PIL import Image
# 打开图片
image = Image.open('test.png')
# 使用pytesseract的image_to_string函数将图片转换为文本
text = pytesseract.image_to_string(image, lang='chi_sim') # 注意这里指定语言为中文('chi_sim')
# 打印提取的文本
print(text) # 这里会显示图片上的文字
```
在这个示例中,`lang='chi_sim'`指定了要使用的Tesseract OCR引擎的语言模型,这里是中文简体(`chi_sim`)。如果报错,可能是因为缺少对应的Tesseract语言包或者路径设置不正确[^1]。
然而,如果你想要执行命令行版本的OCR(如`pytesseract.image_to_osd()`),则需要使用`os.system()`或者`subprocess.run()`来调用外部命令,而不是直接作为函数参数传递[^2]。例如:
```python
import subprocess
command = f"pytesseract {image.filename} output.txt -l osd --psm 0"
subprocess.run(command, shell=True)
with open('output.txt', 'r') as file:
osd_text = file.read()
print(osd_text)
```
这将会把识别结果保存到一个名为`output.txt`的文件中。
from pil import Image imload = Image.OPEN(C:\Users\Administrator\Desktop\测试\test.jpg) im = imload.convert("RGB") width,height = im.size demo=open('rgd.txt','a') for y in range(height) for x in range(width) rgd=im.getpixsl(x,y) rgd=str(rgd) demo.write("\n") demo.close
这段代码有一些语法错误和拼写错误,应该是这样的:
```python
from PIL import Image
imload = Image.open(r'C:\Users\Administrator\Desktop\测试\test.jpg')
im = imload.convert("RGB")
width, height = im.size
demo = open('rgd.txt', 'a')
for y in range(height):
for x in range(width):
rgd = im.getpixel((x, y))
rgd = str(rgd)
demo.write(rgd + "\n")
demo.close()
```
这段代码的作用是读取指定路径下的一张图片,将图片中每个像素的 RGB 值写入到一个名为 rgd.txt 的文本文件中。需要注意几点:
- PIL 库的模块名称为 PIL,而不是 pil;
- Image.open() 方法的参数应该是一个字符串,需要使用引号将其包围;
- getpixel() 方法的参数应该是一个元组,需要使用圆括号将其包围;
- 写入文件时需要使用字符串拼接符号 + 将 RGB 值和换行符连接起来。
阅读全文