Python实现从excel读取数据绘制成精美图像

一、实验介绍

1.1 实验内容

这个世界从古至今一直是一个看颜值的世界。对于我们作报告,写文章时使用的图片,也是一样的。一图胜千言,一张制作精美的图片,不仅能展示大量的信息,更能体现绘图者的水平,审美,与态度。我的老板,国内外多家SCI,EI文章的审稿人,甚至跟我说,一篇文章拿到手里,一眼扫过去,看看数据和图片,就知道这篇文章值不值得发表,水平如何。由此观之,制作一张精美图片的意义,实在重大。本课程实现使用python从excel读取数据,并使用matplotlib绘制成二维图像。这一过程中,将通过一系列操作来美化图像,最终得到一个可以出版级别的图像。本课程对于需要书写实验报告,学位论文,发表文章,做PPT报告的学员具有较大价值。本课程的数据和图像,来源于我的一篇SCI文章,是一真实案例。

1.2 实验知识点

使用xlrd扩展包读取excel数据

使用matplotlib绘制二维图像

美化图像,添加标注,注释,显示Latex风格公式,坐标点处透明化处理等技巧

1.3 实验环境

python2.7

Xfce终端

1.4 适合人群

本课程难度为中等,适合具有Python基础的用户,对于需要书写实验报告,学位论文,发表文章,做PPT报告的学员具有较大价值。

1.5 代码获取

你可以通过下面命令将数据和代码下载到实验楼环境中,作为参照对比进行学习。

$ wget http://labfile.oss.aliyuncs.com/courses/791/finally.py

$ wget http://labfile.oss.aliyuncs.com/courses/791/my_data.xlsx

$ wget http://labfile.oss.aliyuncs.com/courses/791/phase_detector.xlsx

$ wget http://labfile.oss.aliyuncs.com/courses/791/phase_detector2.xlsx

二、开发准备

打开Xfce终端,下载并安装的相关依赖 。

$ sudo apt-get update

$ sudo apt-get install python-dev

$ sudo pip install numpy

$ sudo apt-get install python-matplotlib

$ sudo pip install xlrd

$ sudo apt-get install python-sip

$ sudo apt-get install libqt4-dev

$ sudo apt-get install python-qt4 python-qt4-dev pyqt4-dev-tools qt4-dev-tools

遇到是否安装的询问时,输入y,按回车键继续安装。

三、实验步骤

3.1 绘制一个简单图像,测试扩展包安装是否正常

安装完成matplotlib后,运行一个小程序测试其是否正常。我们来绘制一个非常简单的正弦函数。

import numpy as np

import matplotlib.pyplot as plt

x = np.linspace(0, 10, 500)

dashes = [10, 5, 100, 5]  # 10 points on, 5 off, 100 on, 5 off

fig, ax = plt.subplots()

line1, = ax.plot(x, np.sin(x), ‘–’, linewidth=2,

label=‘Dashes set retroactively’)

line1.set_dashes(dashes)

line2, = ax.plot(x, -1 * np.sin(x), dashes=[30, 5, 10, 5],

label=‘Dashes set proactively’)

ax.legend(loc=‘lower right’)

plt.show()

如果一切正常,应该得到如下显示的图片:

此处输入图片的描述

这段程序来自官方的例程,只作为检验安装包之用。这个图片过于简单,也算不上精美。

3.2 测试xlrd扩展包

xlrd顾名思义,就是excel文件的后缀名.xl文件read的扩展包。这个包只能读取文件,不能写入。写入需要使用另外一个包。但是这个包,其实也能读取.xlsx文件。

从excel中读取数据的过程比较简单,首先从xlrd包导入open_workbook,然后打开excel文件,把每个sheet里的每一行每一列数据都读取出来即可。很明显,这是个循环过程。

from xlrd import open_workbook

x_data1=[]

y_data1=[]

wb = open_workbook(‘phase_detector.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data1.append(values[0])

y_data1.append(values[1])

如果安装包没有问题,这段代码应该能打印出excel表中的数据内容。解释一下 这段代码:打开一个excel文件后,首先对文件内的sheet进行循环,这是最外层循环;在每个sheet内,进行第二次循环,行循环;在每行内,进行列循环,这是第三层循环。在最内层列循环内,取出行列值,复制到新建的values列表内,很明显,源数据有几列,values列表就有几个元素。我们例子中的excel文件有两列,分别对应“角度”和DC值。所以在列循环结束后,我们将取得的数据保存到x_data1和y_data1这两个列表中。

3.3 绘制图像V1.0

第一个版本的功能很简单,从excel中读取数据,然后绘制成图像。具体程序如下:

#!/usr/bin/python

#-- coding: utf-8 --

import matplotlib.pyplot as plt

import xlrd

from xlrd import open_workbook

x_data=[]

y_data=[]

x_volte=[]

temp=[]

wb = open_workbook(‘my_data.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data.append(values[0])

y_data.append(values[1])

plt.plot(x_data, y_data, ‘bo-’,label=u"Phase curve",linewidth=1)

plt.title(u"TR14 phase detector")

plt.legend()

plt.xlabel(u"input-deg")

plt.ylabel(u"output-V")

plt.show()

print ‘over!’

程序简单,显示的效果也是丑到哭:

此处输入图片的描述

从excel中读取数据的程序,上面已经解释过了。这段代码后面的函数是matplotlib绘图的基本格式,此处的输入格式为:

plt.plot(x轴数据, y轴数据, 曲线类型,图例说明,曲线线宽)

图片顶部的名称,由这行语句定义:

plt.title(u"TR14 phase detector")

最后,使用这一语句使能显示:

plt.legend()

3.4 绘制图像V1.1

这个图只绘制了一个表格的数据,我们一共有三个表格。但是就这个一个已经够丑了。我们先来美化一下。首先,坐标轴的问题:横轴的0点对应着纵轴的8,这个明显不行。我们来移动一下坐标轴,使之0点重合:

#!/usr/bin/python

#-- coding: utf-8 --

import matplotlib.pyplot as plt

from pylab import *

import xlrd

from xlrd import open_workbook

x_data=[]

y_data=[]

x_volte=[]

temp=[]

wb = open_workbook(‘my_data.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data.append(values[0])

y_data.append(values[1])

plt.plot(x_data, y_data, ‘bo-’,label=u"Phase curve",linewidth=1)

plt.title(u"TR14 phase detector")

plt.legend()

ax = gca()

ax.spines[‘right’].set_color(‘none’)

ax.spines[‘top’].set_color(‘none’)

ax.xaxis.set_ticks_position(‘bottom’)

ax.spines[‘bottom’].set_position((‘data’,0))

ax.yaxis.set_ticks_position(‘left’)

ax.spines[‘left’].set_position((‘data’,0))

plt.xlabel(u"input-deg")

plt.ylabel(u"output-V")

plt.show()

print ‘over!’

好的,移动坐标轴后,图片稍微顺眼了一点,我们也能明显的看出来,图像与横轴的交点大约在180度附近:

此处输入图片的描述

解释一下移动坐标轴的代码:我们要移动坐标轴,首先要把旧的坐标拆了。怎么拆呢?原图是上下左右四面都有边界刻度的图像,我们首先把右边界拆了不要了,使用语句:

ax.spines[‘right’].set_color(‘none’)

把右边界的颜色设置为不可见,右边界就拆掉了。同理,再把上边界拆掉:

ax.spines[‘top’].set_color(‘none’)

拆完之后,就只剩下我们关心的左边界和下边界了,这俩就是x轴和y轴。然后我们移动这两个轴,使他们的零点对应起来:

ax.xaxis.set_ticks_position(‘bottom’)

ax.spines[‘bottom’].set_position((‘data’,0))

ax.yaxis.set_ticks_position(‘left’)

ax.spines[‘left’].set_position((‘data’,0))

这样,就完成了坐标轴的移动。

3.5 绘制图像V1.2

我们能不能给图像过零点加个标记呢?显示的告诉看图者,过零点在哪,就免去看完图还得猜,要么就要问作报告的人。

#!/usr/bin/python

#-- coding: utf-8 --

import matplotlib.pyplot as plt

from pylab import *

import xlrd

from xlrd import open_workbook

x_data=[]

y_data=[]

x_volte=[]

temp=[]

wb = open_workbook(‘my_data.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data.append(values[0])

y_data.append(values[1])

plt.plot(x_data, y_data, ‘bo-’,label=u"Phase curve",linewidth=1)

plt.annotate(‘zero point’, xy=(180,0), xytext=(60,3), arrowprops=dict(facecolor=‘black’, shrink=0.05),)

plt.title(u"TR14 phase detector")

plt.legend()

ax = gca()

ax.spines[‘right’].set_color(‘none’)

ax.spines[‘top’].set_color(‘none’)

ax.xaxis.set_ticks_position(‘bottom’)

ax.spines[‘bottom’].set_position((‘data’,0))

ax.yaxis.set_ticks_position(‘left’)

ax.spines[‘left’].set_position((‘data’,0))

plt.xlabel(u"input-deg")

plt.ylabel(u"output-V")

plt.show()

print ‘over!’

好的,加上标注的图片,显示效果是这样的:

此处输入图片的描述

标注的添加,使用这句语句:

plt.annotate(标注文字, 标注的数据点, 标注文字坐标, 箭头形状)

这其中,标注的数据点是我们感兴趣的,需要说明的数据,而标注文字坐标,需要我们根据效果进行调节,既不能遮挡原曲线,又要醒目。

3.6 绘制图像V1.3

我们把三组数据都画在这幅图上,方便对比,此外,再加上一组理想数据进行对照。这一次我们再做些改进,把横坐标的单位用Latex引擎显示;不光标记零点,把两边的非线性区也标记出来;

#!/usr/bin/python

#-- coding: utf-8 --

import numpy as np

import matplotlib.pyplot as plt

from xlrd import open_workbook

from pylab import *

x_data=[]

y_data=[]

x_data1=[]

y_data1=[]

x_data2=[]

y_data2=[]

x_data3=[]

y_data3=[]

x_volte=[]

temp=[]

plt.annotate(‘Close loop point’,size=18, xy=(180, 0.1), xycoords=‘data’,

xytext=(-100, 40), textcoords=‘offset points’,

arrowprops=dict(arrowstyle="->",connectionstyle=“arc3,rad=.2”)

)

plt.annotate(’ ', xy=(0, -0.1), xycoords=‘data’,

xytext=(200, -90), textcoords=‘offset points’,

arrowprops=dict(arrowstyle="->",connectionstyle=“arc3,rad=-.2”)

)

plt.annotate(‘Zero point in non-monotonic region’, size=18,xy=(360, 0), xycoords=‘data’,

xytext=(-290, -110), textcoords=‘offset points’,

arrowprops=dict(arrowstyle="->",connectionstyle=“arc3,rad=.2”)

)

wb = open_workbook(‘phase_detector.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data1.append(values[0])

y_data1.append(values[1])

plt.plot(x_data1, y_data1, ‘g’,label=u"Original",linewidth=2)

wb = open_workbook(‘phase_detector2.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data2.append(values[0])

y_data2.append(values[1])

plt.plot(x_data2, y_data2, ‘r’,label=u"Move the pullup resistor",linewidth=2)

wb = open_workbook(‘my_data.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

x_data.append(values[0])

y_data.append(values[1])

plt.plot(x_data, y_data, ‘b’,label=u"Faster D latch and XOR",linewidth=2)

for i in range(360):

x_data3.append(i)

y_data3.append((i-180)*0.052-0.092)

plt.plot(x_data3, y_data3, ‘c’,label=u"The Ideal Curve",linewidth=2)

#plt.title(u"2 \pi phase detector", fontproperties=font)

plt.title(u"2π2\pi2π phase detector",size=20)

plt.legend(loc=0)#显示label

#移动坐标轴代码

ax = gca()

ax.spines[‘right’].set_color(‘none’)

ax.spines[‘top’].set_color(‘none’)

ax.xaxis.set_ticks_position(‘bottom’)

ax.spines[‘bottom’].set_position((‘data’,0))

ax.yaxis.set_ticks_position(‘left’)

ax.spines[‘left’].set_position((‘data’,0))

plt.xlabel(u"ϕ/deg\phi/degϕ/deg",size=20)

plt.ylabel(u"DC/VDC/VDC/V",size=20)

plt.show()

print ‘over!’

看一下显示的效果:

此处输入图片的描述

Latex表示数学公式,使用$表示两个符号之间的内容是数学符号。圆周率就可以简单表示为表示两个符号之间的内容是数学符号。圆周率就可以简单表示为表示两个符号之间的内容是数学符号。圆周率就可以简单表示为\pi,简单到哭,显示效果却很好看。同样的,,简单到哭,显示效果却很好看。同样的,,简单到哭,显示效果却很好看。同样的,\phi$表示角度符号,书写和读音相近,很好记。

对于圆周率,角度公式这类数学符号,使用Latex来表示,是非常方便的。这张图比起上面的要好看得多了。但是,依然觉得还是有些丑。好像用平滑线画出来的图像,并不如用点线画出来的好看。而且点线更能反映实际的数据点。此外,我们的图像跟坐标轴重叠的地方,把坐标和数字都挡住了,看着不太美。

图中的理想曲线的数据,是根据电路原理纯计算出来的,要讲清楚需要较大篇幅,这里就不展开了,只是为了配合比较而用,这部分代码,大家知道即可:

for i in range(360):

x_data3.append(i)

y_data3.append((i-180)*0.052-0.092)

plt.plot(x_data3, y_data3, ‘c’,label=u"The Ideal Curve",linewidth=2)

3.7 绘制图像V1.4

我们再就上述问题,进行优化。优化的过程包括:改变横坐标的显示,使用弧度显示;优化图像与横坐标相交的部分,透明显示;增加网络标度。Talk is cheap, show me the code:

#!/usr/bin/python

#-- coding: utf-8 --

import numpy as np

import matplotlib.pyplot as plt

from xlrd import open_workbook

from pylab import *

x_data=[]

y_data=[]

x_data1=[]

y_data1=[]

x_data2=[]

y_data2=[]

x_data3=[]

y_data3=[]

x_volte=[]

temp=[]

plt.annotate(‘The favorite close loop point’,size=16, xy=(1, 0.1), xycoords=‘data’,

xytext=(-180, 40), textcoords=‘offset points’,

arrowprops=dict(arrowstyle="->",connectionstyle=“arc3,rad=.2”)

)

plt.annotate(’ ', xy=(0.02, -0.2), xycoords=‘data’,

xytext=(200, -90), textcoords=‘offset points’,

arrowprops=dict(arrowstyle="->",connectionstyle=“arc3,rad=-.2”)

)

plt.annotate(‘Zero point in non-monotonic region’, size=16,xy=(1.97, -0.3), xycoords=‘data’,

xytext=(-290, -110), textcoords=‘offset points’,

arrowprops=dict(arrowstyle="->",connectionstyle=“arc3,rad=.2”)

)

wb = open_workbook(‘phase_detector.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

#x_data1.append(values[0])

x_data1.append(values[0]/180.0)

y_data1.append(values[1])

plt.plot(x_data1, y_data1, ‘g–’,label=u"Original",linewidth=2)

wb = open_workbook(‘phase_detector2.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

#x_data2.append(values[0])

x_data2.append(values[0]/180.0)

y_data2.append(values[1])

plt.plot(x_data2, y_data2, ‘r-.’,label=u"Move the pullup resistor",linewidth=2)

wb = open_workbook(‘my_data.xlsx’)

for s in wb.sheets():

print ‘Sheet:’,s.name

for row in range(s.nrows):

print ‘the row is:’,row

values = []

for col in range(s.ncols):

values.append(s.cell(row,col).value)

print values

#x_data.append(values[0])

x_data.append(values[0]/180.0)

y_data.append(values[1])

plt.plot(x_data, y_data, ‘bo–’,label=u"Faster D latch and XOR",linewidth=2)

for i in range(360):

#x_data3.append(i)

x_data3.append(i/180.0)

y_data3.append((i-180)*0.052-0.092)

plt.plot(x_data3, y_data3, ‘c’,label=u"The Ideal Curve",linewidth=2)

plt.title(u"2π2\pi2π phase detector",size=20)

plt.legend(loc=0)#显示label

#移动坐标轴代码

ax = gca()

ax.spines[‘right’].set_color(‘none’)

ax.spines[‘top’].set_color(‘none’)

ax.xaxis.set_ticks_position(‘bottom’)

ax.spines[‘bottom’].set_position((‘data’,0))

ax.yaxis.set_ticks_position(‘left’)

ax.spines[‘left’].set_position((‘data’,0))

plt.xlabel(u"ϕ/rad\phi/radϕ/rad",size=20)#角度单位为pi

plt.ylabel(u"DC/VDC/VDC/V",size=20)

plt.xticks([0, 0.5, 1, 1.5, 2],[r’000’, r’π/2\pi/2π/2’, r’π\piπ’, r’1.5π1.5\pi1.5π’, r’2π2\pi2π’],size=16)

for label in ax.get_xticklabels() + ax.get_yticklabels():

#label.set_fontsize(16)

label.set_bbox(dict(facecolor=‘white’, edgecolor=‘None’, alpha=0.65 ))

plt.grid(True)

plt.show()

print ‘over!’

最终,这张图像的显示效果如下:

此处输入图片的描述

与我们最开始那张图比起来,是不是有种脱胎换骨的感觉?这其中,对图像与坐标轴相交的部分,做了透明化处理,代码为:

for label in ax.get_xticklabels() + ax.get_yticklabels():

#label.set_fontsize(16)

label.set_bbox(dict(facecolor=‘white’, edgecolor=‘None’, alpha=0.65 ))

透明度由其中的参数alpha=0.65控制,如果想更透明,就把这个数改到更小,0代表完全透明,1代表不透明。

而改变横轴坐标显示方式的代码为:

plt.xticks([0, 0.5, 1, 1.5, 2],[r’000’, r’π/2\pi/2π/2’, r’π\piπ’, r’1.5π1.5\pi1.5π’, r’2π2\pi2π’],size=16)

这里直接手动指定x轴的标度。依然是使用Latex引擎来表示数学公式。

四、实验总结

这节课使用python的绘图包matplotlib绘制了一副图像。图像的数据来源于excel数据表。与使用数据表画图相比,通过程序控制绘图,得到了更加灵活和精细的控制,最终绘制除了一幅精美的图像。

五、课后习题

对比每个版本程序的不同,找出优化部分的程序;修改数据来源,从txt或者word中读取数据,绘制图像;将以前使用excel绘制的图像,改用python重新绘制一遍。

python获取excel数据制作有文字和图表的报告_Python实现从excel读取数据并绘制成精美图像...相关推荐

  1. python获取excel数据制作有文字和图表的报告_如何用Python绘制学术报告图表?

    原标题:如何用Python绘制学术报告图表? 作者:ExcelTing 原文:http://cnblogs.com/excelting/p/6507680.html 全文约 3581 字,读完可能需要 ...

  2. Python实现从excel读取数据并绘制成精美图像

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! Pyth ...

  3. python从txt拿取数据_python从txt文件读取数据

    (作为一个python初学者,记录一点学习期间的笔记,方便日后查阅,若有错误或者更加便捷的方法,望指出!) 1.读取TXT文件数据,并对其中部分数据进行划分.一部分作为训练集数据,一部分作为测试集数据 ...

  4. python读取txt文件中的数字_python从txt文件读取数据

    (作为一个python初学者,记录一点学习期间的笔记,方便日后查阅,若有错误或者更加便捷的方法,望指出!) 1.读取TXT文件数据,并对其中部分数据进行划分.一部分作为训练集数据,一部分作为测试集数据 ...

  5. python从文件中读取数据时出现错误_Python 从文件中读取数据

    读取整个文件 # 案例:读取整个文件 # pi_digits.txt 3.1415926535 8979323846 2643383279 # file_reader.py with open ('p ...

  6. 从文件中读取一个long型数_Python 从文件中读取数据

    问题:在python中如何从文件中读取数据,比如有一个mydata.txt文件包含10000行,50列的数据,想提取某几列出来,比如1, 3,5列. 方法一,编一个读取数据的函数. import js ...

  7. python获取本地时间并向服务器发送udp报文_python3通过udp实现组播数据的发送和接收操作...

    本文主要通过对海康摄像头进行抓包,模拟发送了udp包,并抓取摄像头返回的数据包,解析并提取相关信息. 通过抓包发现,海康摄像头发送.接收数据使用udp协议,后来比较发现,使用python模拟起来比较简 ...

  8. python 获取qq群成员信息_Python-获取QQ群成员信息并存入excel及redis并发送邮件

    '''需求: 1.请求qq群的接口,实现传入一个群号 2.把群里每个人的 昵称.群备注.入群时间.qq号,性别,存到redis里面,用hash类型 {"qq_num":XXX,&q ...

  9. [转载] python获取set中某些元素_取集合中元素_Python Set集合

    参考链接: Python set集合 copy() Set集合 阅读本文需要3分钟 2019.09.05 集合(set)是一个无序不重复元素的序列.基本功能是进行成员关系测试和删除重复元素.可以使用大 ...

  10. 利用Python获取公司股票的利润走势并生成图表

    今天在研究通过财报数据获取公司的利润走势图,使用python爬取网页数据就可以做到了 首先是获取网易股票的财报数据 然后解析了十年的数据,用总利润减去所得税获取当年利润 然后得到了年份和利润的两个数组 ...

最新文章

  1. SQL函数Group_concat用法
  2. 浅谈错排公式的推导及应用
  3. 抓包工具-charles安装过程
  4. 95-35-010-Topic-Topic 删除 源码解析
  5. 码云webhook php,PHP实现码云Gitee的WebHook密钥验证算法
  6. 快速线性筛法求素数一般筛法求素数代码
  7. 简单async数据分批处理
  8. 专门查英语单词的软件_查英语单词的软件
  9. 创建对象和实现原型继承的几种方式
  10. dostyle 东格TJ3401 显示器 固件升级
  11. mysql学历统计表,MySQL统计表优化
  12. 医保是不是只有住院才能在单位报销,什么样的病才能报销
  13. iOS开发罗盘/指南针
  14. linux 查看发行版本
  15. Java面试题有哪些
  16. 李航老师新作《机器学习方法》上市了!附购买链接
  17. 正和岛:三大因素决定办公咖啡商业模式之争谁主沉浮
  18. GMOS6803为7频段高精度RTK系统应用桥梁监测
  19. 基于JavaSwing和BeautyEye美化包实现的小型资源管理器
  20. 基于LeNet5的手写数字识别,在ModelArts和GPU上复现

热门文章

  1. 一文看懂互联网支付系统整体架构
  2. 【Js】JavaScript数据类型隐式转换
  3. 绝对估值法和相对估值法
  4. android n sdk,Android SDK (phần 6) pptx
  5. 计算机图片照片查看器为何打不开,电脑看相片时照片查看器打不开怎么办
  6. Excel 批量删除自定义名称
  7. 2020年开始,中国程序员前景一片灰暗,是这样吗?
  8. 视频剪辑计算机配置要求,对于视频剪辑工作,需要什么样的电脑配置才满足要求...
  9. LaTeX插入参考文献教程 | 非BibTeX格式
  10. phpStudy安装框架教程