Python笔记: 读取txt,excel,csv文件并显示;读取一幅彩色图形并显示,同时进行灰度化,并对该图像进行图像增强

目标任务:

  1. 读取txt,excel,csv文件并显示
  2. 读取一幅彩色图形并显示,同时进行灰度化,并对该图像进行图像增强

配置:python3.6、pip20.1
用到的文本资源等我发在我的资源里,零积分即可下载,如有需要请自取。
效果图:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

import csv
import xlrd
#txt
with open(r"C:/Users/Administrator/Desktop/expir1_txt.txt", "r") as f:
    data = f.read()
    print(data)
    for i in range(2):
        print("\n")

#excel
excel_path = "C:/Users/Administrator/Desktop/expir1_xls.xls"
excel = xlrd.open_workbook(excel_path, encoding_override="utf-8")
all_sheet = excel.sheets()
sheet_name = []
sheet_row = []
sheet_col = []
for sheet in all_sheet:
    sheet_name.append(sheet.name)
    print("该Excel共有{0}个sheet,当前sheet名称为{1},该sheet共有{2}行,{3}列".format(len(all_sheet), sheet.name, sheet.nrows, sheet.ncols))
    for each_row in range(sheet.nrows):
        print("当前为%s行:" % each_row, type(each_row))
        print(sheet.row_values(each_row), type(sheet.row_values(each_row)))
    if sheet.nrows:#如果表非空,打印第一行
        first_row_value = sheet.row_values(0)  # 打印指定的某一行
        print("第一行的数据是:%s" % first_row_value)
for i in range(2):
    print("\n")


#csv
with open('C:/Users/Administrator/Desktop/expir1_csv.csv') as f:
    reader = csv.reader(f)
    for row in reader:
        print(row)
for i in range(2):
    print("\n")

#图片灰度化
from skimage import io,transform, data
import matplotlib.pyplot as plt
img=io.imread('C:/Users/Administrator/Desktop/expir1_jpg.jpg')
io.imshow(img)
plt.show()

img_gray=io.imread('C:/Users/Administrator/Desktop/expir1_jpg.jpg',as_gray=True)
io.imshow(img_gray)
plt.show()

# 调亮
from skimage import data, exposure, img_as_float
import matplotlib.pyplot as plt
image = img_as_float(data.moon())
gam2= exposure.adjust_gamma(image, 0.5)
plt.figure('adjust_gamma',figsize=(8,8))

plt.subplot(131)
plt.title('origin image')
plt.imshow(image,plt.cm.gray)
plt.axis('on')

plt.subplot(133)
plt.title('gamma=0.5')
plt.imshow(gam2,plt.cm.gray)
plt.axis('on')
plt.show()
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python为一种高级编程语言,可以编写各种应用程序,包括读取和处理CSV文件。PyQt5是一种Python库,可以用于创建用户界面(GUI)应用程序。它可以通过调用QTableWidget类来实现CSV文件读取和实时显示。 首先,需要导入PyQt5和pandas库。pandas库是专门用于处理CSV文件的库。可以使用read_csv()方法读取CSV文件,并将其存储为pandas数据框。然后,使用QTableWidget类来创建一个表格,其中每行代表一个CSV文件中的数据行。可以使用setItem()方法将数据单元格放入表格中。最后,使用QWidget类和QGridLayout实现一个用户界面,将表格置于用户界面上并显示。 下面是一些示例代码: import sys from PyQt5.QtWidgets import QApplication, QWidget, QTableWidget, QTableWidgetItem, QVBoxLayout, QHBoxLayout import pandas as pd # 读取CSV文件并将其转换为pandas数据框 df = pd.read_csv('example.csv', delimiter=',') # 创建QTableWidget并填充它 table = QTableWidget() table.setColumnCount(len(df.columns)) table.setRowCount(len(df.index)) for i in range(len(df.index)): for j in range(len(df.columns)): table.setItem(i, j, QTableWidgetItem(str(df.iloc[i, j]))) # 创建QWidget和QGridLayout并放置QTableWidget widget = QWidget() layout = QVBoxLayout() top_layout = QHBoxLayout() layout.addLayout(top_layout) layout.addWidget(table) widget.setLayout(layout) # 显示QWidget widget.show() sys.exit(app.exec_()) 这段代码将在窗口中显示CSV文件中的所有数据,并使其变得可编辑。可以更改代码以实现不同的功能,例如只显示特定列或行,或者添加整个用户界面以进行交互。总之,Python和PyQt5提供了很多灵活性和功能,使数据处理变得更加容易和有用。 ### 回答2: Python语言作为一种高效的编程语言,在数据处理方面具有突出的优势。而利用Python读取CSV文件并实时显示则是一种非常实用的数据处理方法,特别是对于需要实时处理数据的人士,这种方法可以大大提高数据处理的效率。下面我就来详细介绍一下Python PyQt5读取CSV文件并实时显示的方法。 首先,需要用到的库有PyQt5、pandas和matplotlib。pandas用来读取CSV文件,matplotlib用来绘制图形,而PyQt5则用来实现图形化界面。这些库都可以通过pip命令进行安装,安装命令如下: pip install pyqt5 pandas matplotlib 其次,需要在Python程序中导入所需的库,代码如下: ```python import sys import pandas as pd import matplotlib.pyplot as plt from PyQt5.QtCore import QTimer, Qt from PyQt5.QtWidgets import QApplication, QMainWindow, QTableView from PyQt5.QtGui import QColor, QBrush ``` 接着,就可以开始实现Python PyQt5读取CSV文件并实时显示的功能了。首先需要创建一个QT主窗口,代码如下: ```python class MainWindow(QMainWindow): def __init__(self): super().__init__() self.table = QTableView(self) self.setCentralWidget(self.table) self.data = pd.DataFrame() self.timer = QTimer(self) self.timer.timeout.connect(self.update_data) self.timer.start(1000) self.show() ``` 在这段代码中,首先创建了一个QTableView控件,并将其设为主窗口的中心窗口。然后创建了一个空的DataFrame来存储CSV文件中的数据,并创建一个定时器用来定时更新数据。每隔1秒钟就会触发update_data函数,该函数用来读取CSV文件中的数据,然后将其显示在QTableView控件中。在MainWindow的构造函数中调用show函数可以显示主窗口。需要注意的是,这里的CSV文件路径需要修改为自己的文件路径。 ```python def update_data(self): self.data = pd.read_csv('data.csv') model = PandasModel(self.data) self.table.setModel(model) ``` 接下来,需要创建一个PandasModel类,用来将DataFrame转换为用于显示在QTableView控件中的模型。代码如下: ```python class PandasModel(QTableView): def __init__(self, data): super(PandasModel, self).__init__() self.data = data self.model = None self.init_ui() def init_ui(self): self.model = PandasTableModel(self.data) self.setModel(self.model) class PandasTableModel(QtCore.QAbstractTableModel): def __init__(self, data): QtCore.QAbstractTableModel.__init__(self) self.data = data self.columns = list(self.data.columns) def rowCount(self, parent=None): return self.data.shape[0] def columnCount(self, parent=None): return self.data.shape[1] def data(self, index, role=Qt.DisplayRole): row = index.row() col = index.column() if role == Qt.DisplayRole: return str(self.data.iloc[row, col]) if role == Qt.BackgroundRole: color = self.data.iloc[row, col] if col == 2: if color == 'red': return QBrush(QColor(255, 0, 0)) elif color == 'yellow': return QBrush(QColor(255, 255, 0)) elif color == 'green': return QBrush(QColor(0, 255, 0)) return None def headerData(self, col, orientation, role): if orientation == Qt.Horizontal and role == Qt.DisplayRole: return self.columns[col] return None ``` 在PandasModel类中,首先重载了构造函数,并在构造函数中调用了init_ui函数。init_ui函数中创建了一个PandasTableModel对象,并将其设置为QTableView控件的模型。PandasTableModel类是继承自QtCore.QAbstractTableModel的,需要实现rowCount、columnCount、data和headerData等方法。其中data方法用来设置单元格显示的数据,headerData方法用来设置列名。需要注意的是,在data方法中可以通过设置Qt.BackgroundRole来设置单元格的背景色,这里是根据CSV文件中的颜色列来设置的。 最后,需要创建一个实例化MainWindow的代码,以便在运行Python程序时可以直接运行读取CSV文件并实时显示的程序。代码如下: ```python if __name__ == '__main__': app = QApplication(sys.argv) main_window = MainWindow() sys.exit(app.exec_()) ``` 至此,Python PyQt5读取CSV文件并实时显示的程序已经完成。通过这种方法,可以方便地读取CSV文件,并实时显示其中的数据,大大提高了数据处理效率,同时也增强了程序的可读性和可操作性。 ### 回答3: Python是一种高级编程语言,它非常流行于数据科学和人工智能领域。 PyQt5是一种Python GUI工具包,它可以让我们开发具有专业外观和各种控件的桌面应用程序。PyQt5包含了Qt5的Python绑定,使得其在使用C++来编写展示层时孩能提供更高的灵活性和可移植性,加上Python语法简洁,易于理解,可以使得开发GUI应用更为便捷和可靠。 读取CSV文件并实时显示数据是数据分析中常见的任务之一。在Python中,使用Pandas库可以很容易地读取CSV文件并在内存中表示数据。实时显示数据可以使用Matplotlib来实现,Matplotlib是Python的一个2D绘图库,提供了许多高质量的绘图工具。 下面是读取CSV文件并实时显示的具体步骤: 1.先安装好相应的依赖库Pandas、PyQt5和Matplotlib。 2.使用Pandas读取CSV文件的数据,并将其转换为Pandas的数据帧(DataFrame)格式。 ```python import pandas as pd data = pd.read_csv('file.csv') df = pd.DataFrame(data) ``` 3.在PyQt5中创建一个窗口,并在其中创建一个Matplotlib的画布并添加到窗口中。 ```python from PyQt5.QtWidgets import QApplication, QMainWindow from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas from matplotlib.figure import Figure class MainWindow(QMainWindow): def __init__(self, parent=None): super(MainWindow, self).__init__(parent) self.figure = Figure() self.canvas = FigureCanvas(self.figure) self.setCentralWidget(self.canvas) ``` 4.使用Matplotlib绘制数据,并将其添加到画布中。 ```python import matplotlib.pyplot as plt def plot_data(df): plt.plot(df['Column1'], df['Column2']) plt.xlabel('X label') plt.ylabel('Y label') return plt ``` 5.在PyQt5的窗口中更新Matplotlib画布上的内容。 ```python def update_plot(canvas, plt): canvas.restore_region(background) ax.draw_artist(line1) canvas.blit(ax.bbox) # 更新可以调用多次 #plt.plot(...) plt.pause(0.001) ``` 整体代码如下: ```python import pandas as pd import matplotlib.pyplot as plt from PyQt5.QtWidgets import QApplication, QMainWindow from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas from matplotlib.figure import Figure class MainWindow(QMainWindow): def __init__(self, parent=None): super(MainWindow, self).__init__(parent) # 读取CSV文件 data = pd.read_csv('file.csv') self.df = pd.DataFrame(data) # 创建Matplotlib图形 self.figure = Figure() self.canvas = FigureCanvas(self.figure) self.setCentralWidget(self.canvas) # 绘制图形 self.ax = self.figure.add_subplot(111) self.ax.set_xlabel('X label') self.ax.set_ylabel('Y label') self.line1, = self.ax.plot(self.df['Column1'], self.df['Column2']) # 绑定事件 timer = QtCore.QTimer(self) timer.timeout.connect(self.update_plot) timer.start(1000) def update_plot(self): # 重新读取CSV文件 data = pd.read_csv('file.csv') df = pd.DataFrame(data) # 更新数据 self.line1.set_xdata(df['Column1']) self.line1.set_ydata(df['Column2']) # 绘制图形 self.ax.draw_artist(self.line1) # 刷新画布 self.canvas.draw() if __name__ == '__main__': app = QApplication([]) window = MainWindow() window.show() app.exec_() ``` 这样就可以在PyQt5窗口中实现对CSV文件的实时显示了。此外,我们还可以通过增加图例、修改颜色和样式等方式进行更加高级的数据可视化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值