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 16:50:12 浏览: 132
你可以尝试在写入文件时使用逗号(,)代替制表符(\t),并使用换行符(\n)而不是写入“\n”字符串。这样,Excel会自动将每个元素放在单独的单元格中。
修改后的代码如下:
```
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] + ",") # 使用逗号代替制表符
demo.write("\n") # 使用换行符
```
请注意,我还使用了上下文管理器来打开文件,这样在完成操作后会自动关闭文件,而无需显式调用`demo.close()`。
相关问题
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 值和换行符连接起来。
阅读全文