- python 读excel每行替换_Python脚本操作Excel实现批量替换功能
weixin_39646695
python读excel每行替换
Python脚本操作Excel实现批量替换功能大家好,给大家分享下如何使用Python脚本操作Excel实现批量替换。使用的工具Openpyxl,一个处理excel的python库,处理excel,其实针对的就是WorkBook,Sheet,Cell这三个最根本的元素~明确需求原始excel如下我们的目标是把下面excel工作表的sheet1表页A列的内容“替换我吧”批量替换为B列的“我用来替换的
- 【Python系列PyCharm控制台pip install报错】如何解决pip安装报错ModuleNotFoundError: No module named ‘openpyxl’问题
万粉变现经纪人
全栈Bug解决方案专栏pythonpycharmpip开发语言idepandasnumpy
【Python系列PyCharm控制台pipinstall报错】如何解决pip安装报错ModuleNotFoundError:Nomodulenamed‘openpyxl’问题摘要在使用PyCharm开发Python项目时,往往需要通过pip在控制台安装第三方库。但有时即使执行了pipinstallopenpyxl,依旧在控制台或运行时看到:ModuleNotFoundError:Nomodule
- pandas库 DataFrame的常见操作
目录一.Pandas库的核心特点与应用场景1.表格数据处理2.与NumPy的区别3.数据转换二.Pandas与OpenPyXl的对比三.DataFrame与Series数据类型四.DataFrame常用操作排序:df.sort_values(by='列名',ascending=False)按指定列降序排序,整行数据同步调整,当参数值为ture时则为升序排序或默认升序排序数据替换:df['列名'].
- openpyxl 使用
feuiw
pythonpythonexcel
简介openpyxl是一个用于读写Excel2010及以上版本(.xlsx/.xlsm/.xltx/.xltm)文件的Python库。安装pipinstallopenpyxl教程openxl文档book创建excelWorkbookfromopenpyxlimportWorkbookwb=Workbook()ws=wb.activewb.save('example.xlsx')读取现有excell
- python生成/读取Excel文件
夏末蝉未鸣01
pythonpythonexcel
一、生成Excel文件安装模块pipinstallopenpyxl代码示例importopenpyxlfromopenpyxl.stylesimportFontfromopenpyxl.stylesimportPatternFillfromopenpyxl.drawing.imageimportImagewb=openpyxl.Workbook()#创建excel文件sheet1=wb.activ
- python办自动化--读取邮箱中特定的邮件,并下载特定的附件
宝山哥哥
python办公自动化python自动化信息可视化
系列文章目录python办公自动化–数据可视化(pandas+matplotlib)–生成条形图和饼状图python办公自动化–数据可视化(pandas+matplotlib)–生成折线图python办公自动化–数据可视化(pandas读取excel文件,matplotlib生成可视化图表)python办公自动化-openpyxl学习-工资表生成工资条python办公自动化–使用将csv大文件分割
- 把文件夹下所有的excle写入word文件中
[自由之路]
word
把文件夹下所有的excle写入word文件中frompathlibimportPath,PurePathfromopenpyxlimportload_workbookfromdocximportDocument#当前目录p=Path('./')#获取所有xlsx文件files=[xforxinp.iterdir()ifx.is_file()andPurePath(x).match('*.xlsx'
- python 合并多个excle到一个
合并多个excle到一个frompathlibimportPathfromopenpyxlimportWorkbook,load_workbook#初始化#输入的文件夹目录current_dir=Path('./')#输出的文件夹目录output_dir=Path('../exile')#创建输出目录(如果不存在)output_dir.mkdir(exist_ok=True,parents=Tru
- Python办公—Excel嵌入图片提取&重命名(包含重复图片)
小庄-Python办公
Python办公自动化pythonexcelExcel图片获取Excel批量获取嵌入图片Excel嵌入图片
目录专栏导读背景解决方案1、背景介绍2、库的介绍①:openpyxl3、库的安装4、核心代码5、完整代码总结专栏导读欢迎来到Python办公自动化专栏—Python处理办公问题,解放您的双手️博客主页:请点击——>一晌小贪欢的博客主页求关注该系列文章专栏:请点击——>Python办公自动化专栏求订阅此外还有爬虫专栏:请点击——>Python爬虫基础专栏求订阅此外还有python基础专栏:请点击—
- [特殊字符] Excel 读取收件人 + Outlook 批量发送带附件邮件 —— Python 自动化实战
happydog007
python自动化办公exceloutlookpython
许多公司定期需要将不同部门或客户的报告发送给指定人员。手动操作容易出错、耗时且繁琐。今天这篇文章教你如何利用Python实现:从Excel中读取“收件人+抄送人+附件文件路径”;使用win32com.client调用Outlook自动生成并发送邮件;✅附加模板正文,并保持批量发送规范无需手工操作。从Excel中读取部门、收件人与附件路径fromopenpyxlimportload_workbook
- HTML表格导出为Excel文件的实现方案
~风清扬~
前端技术htmlexcel前端
1、前端javascript可通过mime类型、blob对象或专业库(如sheetjs)实现html表格导出excel,适用于中小型数据量;2、服务器端方案利用后端语言(如python的openpyxl、java的apachepoi)处理复杂报表和大数据,确保安全性与格式控制;3、常见问题包括数据类型识别错误、样式丢失、大文件卡顿、浏览器兼容性及乱码,需通过设置单元格类型、使用后端样式api、分页
- 【Python3数据分析第34章】Python3数据分析:文件操作总结
韩公子的Linux大集市
Python3数据分析数据分析pythonlinux
文章目录Python3数据分析:文件操作总结1.文件基本操作打开文件关闭文件2.文本文件操作读取文件写入文件3.二进制文件操作读取二进制文件写入二进制文件处理二进制数据4.CSV文件操作使用csv模块5.JSON文件操作使用json模块6.Excel文件操作使用openpyxl(处理.xlsx文件)7.数据库文件操作SQLite数据库8.文件路径处理使用os.path模块使用pathlib(Pyt
- 自学Python笔记开篇
奔跑吧茄子
python
自学Python笔记开篇突然喜欢上了Python,大体研究了一下,写了一个excel数据比对的小工具,边学边写,收获很多。这期间学习了xlrd、openpyxl、pandas处理excel文件的基本常识,有时间整理一下,对菜鸟入门或许有帮助。
- 使用openpyxl的append写入excel出现AttributeError的可能原因
2301_79717431
excel
之前源码是这样的,importopenpyxlfromopenpyxlimportWorkbookwb=openpyxl.load_workbook('text.xlsx')sheet=wb.activec=[1,2,"a",4]sheet.append(c)sheet.save('text.xlsx')最后一句有问题,save需要保存的时wb这个文件,而不是sheet表格!
- openpyxl学习-iter_rows
qq_43632431
python学习笔记学习
在openpyxl中,iter_rows是一个非常有用的函数,它允许你遍历一个工作表中的所有行,这在你需要处理大量的行而不需要一次性加载所有行到内存时非常有用。语法:worksheet.iter_rows(min_row=1,#最小行,从哪一行开始,默认值为1。max_row=None,#最大行,到那一行结束,默认值为工作表中的最大行数。min_col=1,#最小列,从哪一列开始,默认值为1。ma
- openpyxl 学习- iter_rows和iter_cols
qq_43632431
python学习笔记学习
iter_cols是openpyxl库中的一个方法,用于按列迭代读取内容。在openpyxl中,iter_cols和iter_cols方法用于返回一个生成器,该生成器按列遍历给定的行范围。它接受四个参数:min_row,min_col,max_row和max_col,这些参数定义了要迭代的单元格范围。1语法:worksheet.iter_rows(min_row=1,#最小行max_row=Non
- 【Python】openpyxl的使用方法
宅男很神经
python开发语言
openpyxl深度解析与实战指南openpyxl是一个用于读取和写入Excel2010xlsx/xlsm/xltx/xltm文件的Python库。它允许Python开发者通过编程方式创建、修改和查询Excel文件中的数据、样式、图表等内容,是Python进行Excel自动化办公不可或缺的利器。第一章:openpyxl概述与基础1.1什么是openpyxl?openpyxl是一个纯Python实现
- 掌握openpyxl:Excel自动化处理全指南
openpyxl基础用法openpyxl是一个用于处理Excel文件(.xlsx/.xlsm)的Python库,支持读取、修改和创建Excel文档。以下是其常见用法的详细介绍:一、基础操作:打开与保存文件fromopenpyxlimportload_workbookfromopenpyxlimportWorkbook#1.加载现有Excel文件wb=load_workbook('example.x
- Python:openpyxl在excel中读取url并下载、插入图片
猫大鸡腿
pythonexcel开发语言
本文展示了如何使用openpyxl等一系列包创建新工作表或在已有工作表中插入图片的方法。第一步:导入包requests包用于下载图片;openpyxl包用于围绕excel的一系列操作(3.0.9版本,如果出现奇怪报错一直解决不了建议使用这个版本);PIL(pillow9.1.0)包用于图像处理;io包用于沟通不同包对图像的接收和输出。importrequestsimportopenpyxlfrom
- 【Python 跨工作簿复制表格技巧大全 (从一个excel文件复制sheet到另一个excel文件)】
场景在工作中,我们有时候会将一个excel中的sheet复制到一个新的excel中。这通常我们如果使用pandas中的dataframe就能轻松实现,但是当我们遇到有合并单元格的多级表头的excel,dataframe处理起来就麻烦多了,我们更倾向于使用openpyxl库与pandas结合起来处理数据。这个时候就会有一个问题:你会发现openpyxl复制的时候,按照网上的方法,通常只会复制数据,将
- python实现从word导出表格到excel小记
--洗洗睡吧--
笔记
直接上代码#-*-coding:utf-8-*-importdocximportopenpyxlimportosimportsysimportreimportsubprocess#importxlwtimporttimefromdocximportDocument#导入库defread_word(wd):document=Document(wd)#读入文件tables=document.table
- python操作excel的库
淼_@淼
pythonpython
python在操作excel的时候,用到很多库,常用的有xlwings、xlrd、xlwt、xlutils、xlsxwriter、openpyxl、pandas。这几个库都是第三方库,需要install和import才能使用xlrd和xlwt是早期支持操作excel的库,目前最新版本都只支持xls格式,不支持xlsx格式文件。xlrd负责读取excel文件,xlwt负责对excel进行写的操作。x
- Python+Openpyxl操作Excel
聪明的一休哥哥
Python办公自动化接口测试爬虫excelpython爬虫数据分析办公自动化
目录一、安装二、Excel工作流程三、示例:创建Excel并更新数据四、示例:读取Excel并更新数据五、工作簿操作六、工作表操作七、单元格操作7.1更新数据7.2获取行数和列数7.3删除行和列7.4合并单元格7.5单元格格式7.6单元格样式7.7设置单元格行高和列宽大家好,我是聪明的一休哥哥!Excel有两种常见的格式:xls和xlsx,Python的第三方库openpyxl,可以用来处理xls
- pandas 批量读取excel_Pandas进阶Excel(一)——读取
铺地板
pandas批量读取excel
前面利用python的openpyxl库对excel做了简单基础操作,大家可以打开公众号右下角往期回顾,可以复习查看。今天开始介绍python可以操作Excel的另一个强大的库——pandas库。个人认为,pandas库对于操作Excel有着极好的支撑。在数据导入、数据清洗、数据计算、数据导出都有着完整性的支撑,是一个提供高性能易用数据类型和分析工具,并且用一段时间你就会发现如果拿pandas只操
- python openpyxl.chart库绘制excel图表的使用
向飞飞(码龄1年)
开发语言python
写在前面:目前项目需要用python调excel在excel里画直方图,需要画图、设置数据标签之类的,很多参数打开csdn和百度搜索都说的不清不楚,直接放一大堆代码没有任何解释,官方文档全英文没解释,摸清每个参数用法后在此记录,望给下个需要的人提供方便,感谢阅览。简介:openpyxl是一个python库,用于读写Excel文件。openpyxl.chart是openpyxl中的一个模块,用于在E
- 获取指定目录下所有的doc & docx 文件名
A3word_C
python
写周月报时,经常用到需要统计一个文件夹下有n个子文件夹需要统计文件名的情况可以用到importosimportglobimportopenpyxldefget_doc_files(path):"""获取指定目录下所有doc文件的名称"""doc_files=[]fordirpath,dirnames,filenamesinos.walk(path):forfilenameinfilenames:i
- 5 分钟掌握 openpyxl 操作:Python 轻松处理 Excel
MetalTrader
pythonexcel
各种数据需要导入Excel?多个Excel要合并?目前,Python处理Excel文件有很多库,openpyxl算是其中功能和性能做的比较好的一个。接下来我将为大家介绍各种Excel操作。打开Excel文件新建一个Excel文件 >>> from openpyxl import Workbook >>> wb = Workbook()打开现有Excel文件 >>> from op
- python实现excel保护
mangge08
windows
importopenpyxlfromopenpyxl.utilsimportget_column_letterfromopenpyxl.stylesimportProtectionfromopenpyxl.worksheet.protectionimportSheetProtectiondefprotect_excel_sheet(input_file,output_file,password,p
- Python从Excel读取数据并生成图表的方法详解
Alex艾力的IT数字空间
IT类项目管理经验及方法论python开发语言大数据etl工程师图像处理单元测试低代码
Python从Excel读取数据并生成图表:一、Pandas+Matplotlib/Seaborn(静态图表)适用场景:快速数据清洗+基础到高级可视化步骤:安装库:pipinstallpandasmatplotlibseabornopenpyxl读取与处理数据:importpandasaspddf=pd.read_excel("data.xlsx",sheet_name="Sheet1")#读取E
- Python Excel 文件处理:openpyxl 与 pandas 库完全指南
在数据处理和分析过程中,Excel文件是最常见的数据存储格式之一。Python提供了多个库来处理Excel文件,其中openpyxl和pandas是最常用的两个库。它们各自有独特的优势,适用于不同的需求。本文将详细介绍如何使用这两个库来处理Excel文件。一、使用openpyxl处理Excel文件openpyxl是一个纯Python编写的库,用于读取、写入、修改Excel文件(.xlsx格式)。它
- JVM StackMapTable 属性的作用及理解
lijingyao8206
jvm字节码Class文件StackMapTable
在Java 6版本之后JVM引入了栈图(Stack Map Table)概念。为了提高验证过程的效率,在字节码规范中添加了Stack Map Table属性,以下简称栈图,其方法的code属性中存储了局部变量和操作数的类型验证以及字节码的偏移量。也就是一个method需要且仅对应一个Stack Map Table。在Java 7版
- 回调函数调用方法
百合不是茶
java
最近在看大神写的代码时,.发现其中使用了很多的回调 ,以前只是在学习的时候经常用到 ,现在写个笔记 记录一下
代码很简单:
MainDemo :调用方法 得到方法的返回结果
- [时间机器]制造时间机器需要一些材料
comsci
制造
根据我的计算和推测,要完全实现制造一台时间机器,需要某些我们这个世界不存在的物质
和材料...
甚至可以这样说,这种材料和物质,我们在反应堆中也无法获得......
 
- 开口埋怨不如闭口做事
邓集海
邓集海 做人 做事 工作
“开口埋怨,不如闭口做事。”不是名人名言,而是一个普通父亲对儿子的训导。但是,因为这句训导,这位普通父亲却造就了一个名人儿子。这位普通父亲造就的名人儿子,叫张明正。 张明正出身贫寒,读书时成绩差,常挨老师批评。高中毕业,张明正连普通大学的分数线都没上。高考成绩出来后,平时开口怨这怨那的张明正,不从自身找原因,而是不停地埋怨自己家庭条件不好、埋怨父母没有给他创造良好的学习环境。
- jQuery插件开发全解析,类级别与对象级别开发
IT独行者
jquery开发插件 函数
jQuery插件的开发包括两种: 一种是类级别的插件开发,即给
jQuery添加新的全局函数,相当于给
jQuery类本身添加方法。
jQuery的全局函数就是属于
jQuery命名空间的函数,另一种是对象级别的插件开发,即给
jQuery对象添加方法。下面就两种函数的开发做详细的说明。
1
、类级别的插件开发 类级别的插件开发最直接的理解就是给jQuer
- Rome解析Rss
413277409
Rome解析Rss
import java.net.URL;
import java.util.List;
import org.junit.Test;
import com.sun.syndication.feed.synd.SyndCategory;
import com.sun.syndication.feed.synd.S
- RSA加密解密
无量
加密解密rsa
RSA加密解密代码
代码有待整理
package com.tongbanjie.commons.util;
import java.security.Key;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerat
- linux 软件安装遇到的问题
aichenglong
linux遇到的问题ftp
1 ftp配置中遇到的问题
500 OOPS: cannot change directory
出现该问题的原因:是SELinux安装机制的问题.只要disable SELinux就可以了
修改方法:1 修改/etc/selinux/config 中SELINUX=disabled
2 source /etc
- 面试心得
alafqq
面试
最近面试了好几家公司。记录下;
支付宝,面试我的人胖胖的,看着人挺好的;博彦外包的职位,面试失败;
阿里金融,面试官人也挺和善,只不过我让他吐血了。。。
由于印象比较深,记录下;
1,自我介绍
2,说下八种基本类型;(算上string。楼主才答了3种,哈哈,string其实不是基本类型,是引用类型)
3,什么是包装类,包装类的优点;
4,平时看过什么书?NND,什么书都没看过。。照样
- java的多态性探讨
百合不是茶
java
java的多态性是指main方法在调用属性的时候类可以对这一属性做出反应的情况
//package 1;
class A{
public void test(){
System.out.println("A");
}
}
class D extends A{
public void test(){
S
- 网络编程基础篇之JavaScript-学习笔记
bijian1013
JavaScript
1.documentWrite
<html>
<head>
<script language="JavaScript">
document.write("这是电脑网络学校");
document.close();
</script>
</h
- 探索JUnit4扩展:深入Rule
bijian1013
JUnitRule单元测试
本文将进一步探究Rule的应用,展示如何使用Rule来替代@BeforeClass,@AfterClass,@Before和@After的功能。
在上一篇中提到,可以使用Rule替代现有的大部分Runner扩展,而且也不提倡对Runner中的withBefores(),withAfte
- [CSS]CSS浮动十五条规则
bit1129
css
这些浮动规则,主要是参考CSS权威指南关于浮动规则的总结,然后添加一些简单的例子以验证和理解这些规则。
1. 所有的页面元素都可以浮动 2. 一个元素浮动后,会成为块级元素,比如<span>,a, strong等都会变成块级元素 3.一个元素左浮动,会向最近的块级父元素的左上角移动,直到浮动元素的左外边界碰到块级父元素的左内边界;如果这个块级父元素已经有浮动元素停靠了
- 【Kafka六】Kafka Producer和Consumer多Broker、多Partition场景
bit1129
partition
0.Kafka服务器配置
3个broker
1个topic,6个partition,副本因子是2
2个consumer,每个consumer三个线程并发读取
1. Producer
package kafka.examples.multibrokers.producers;
import java.util.Properties;
import java.util.
- zabbix_agentd.conf配置文件详解
ronin47
zabbix 配置文件
Aliaskey的别名,例如 Alias=ttlsa.userid:vfs.file.regexp[/etc/passwd,^ttlsa:.:([0-9]+),,,,\1], 或者ttlsa的用户ID。你可以使用key:vfs.file.regexp[/etc/passwd,^ttlsa:.: ([0-9]+),,,,\1],也可以使用ttlsa.userid。备注: 别名不能重复,但是可以有多个
- java--19.用矩阵求Fibonacci数列的第N项
bylijinnan
fibonacci
参考了网上的思路,写了个Java版的:
public class Fibonacci {
final static int[] A={1,1,1,0};
public static void main(String[] args) {
int n=7;
for(int i=0;i<=n;i++){
int f=fibonac
- Netty源码学习-LengthFieldBasedFrameDecoder
bylijinnan
javanetty
先看看LengthFieldBasedFrameDecoder的官方API
http://docs.jboss.org/netty/3.1/api/org/jboss/netty/handler/codec/frame/LengthFieldBasedFrameDecoder.html
API举例说明了LengthFieldBasedFrameDecoder的解析机制,如下:
实
- AES加密解密
chicony
加密解密
AES加解密算法,使用Base64做转码以及辅助加密:
package com.wintv.common;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.BASE64Decod
- 文件编码格式转换
ctrain
编码格式
package com.test;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
- mysql 在linux客户端插入数据中文乱码
daizj
mysql中文乱码
1、查看系统客户端,数据库,连接层的编码
查看方法: http://daizj.iteye.com/blog/2174993
进入mysql,通过如下命令查看数据库编码方式: mysql> show variables like 'character_set_%'; +--------------------------+------
- 好代码是廉价的代码
dcj3sjt126com
程序员读书
长久以来我一直主张:好代码是廉价的代码。
当我跟做开发的同事说出这话时,他们的第一反应是一种惊愕,然后是将近一个星期的嘲笑,把它当作一个笑话来讲。 当他们走近看我的表情、知道我是认真的时,才收敛一点。
当最初的惊愕消退后,他们会用一些这样的话来反驳: “好代码不廉价,好代码是采用经过数十年计算机科学研究和积累得出的最佳实践设计模式和方法论建立起来的精心制作的程序代码。”
我只
- Android网络请求库——android-async-http
dcj3sjt126com
android
在iOS开发中有大名鼎鼎的ASIHttpRequest库,用来处理网络请求操作,今天要介绍的是一个在Android上同样强大的网络请求库android-async-http,目前非常火的应用Instagram和Pinterest的Android版就是用的这个网络请求库。这个网络请求库是基于Apache HttpClient库之上的一个异步网络请求处理库,网络处理均基于Android的非UI线程,通
- ORACLE 复习笔记之SQL语句的优化
eksliang
SQL优化Oracle sql语句优化SQL语句的优化
转载请出自出处:http://eksliang.iteye.com/blog/2097999
SQL语句的优化总结如下
sql语句的优化可以按照如下六个步骤进行:
合理使用索引
避免或者简化排序
消除对大表的扫描
避免复杂的通配符匹配
调整子查询的性能
EXISTS和IN运算符
下面我就按照上面这六个步骤分别进行总结:
- 浅析:Android 嵌套滑动机制(NestedScrolling)
gg163
android移动开发滑动机制嵌套
谷歌在发布安卓 Lollipop版本之后,为了更好的用户体验,Google为Android的滑动机制提供了NestedScrolling特性
NestedScrolling的特性可以体现在哪里呢?<!--[if !supportLineBreakNewLine]--><!--[endif]-->
比如你使用了Toolbar,下面一个ScrollView,向上滚
- 使用hovertree菜单作为后台导航
hvt
JavaScriptjquery.nethovertreeasp.net
hovertree是一个jquery菜单插件,官方网址:http://keleyi.com/jq/hovertree/ ,可以登录该网址体验效果。
0.1.3版本:http://keleyi.com/jq/hovertree/demo/demo.0.1.3.htm
hovertree插件包含文件:
http://keleyi.com/jq/hovertree/css
- SVG 教程 (二)矩形
天梯梦
svg
SVG <rect> SVG Shapes
SVG有一些预定义的形状元素,可被开发者使用和操作:
矩形 <rect>
圆形 <circle>
椭圆 <ellipse>
线 <line>
折线 <polyline>
多边形 <polygon>
路径 <path>
- 一个简单的队列
luyulong
java数据结构队列
public class MyQueue {
private long[] arr;
private int front;
private int end;
// 有效数据的大小
private int elements;
public MyQueue() {
arr = new long[10];
elements = 0;
front
- 基础数据结构和算法九:Binary Search Tree
sunwinner
Algorithm
A binary search tree (BST) is a binary tree where each node has a Comparable key (and an associated value) and satisfies the restriction that the key in any node is larger than the keys in all
- 项目出现的一些问题和体会
Steven-Walker
DAOWebservlet
第一篇博客不知道要写点什么,就先来点近阶段的感悟吧。
这几天学了servlet和数据库等知识,就参照老方的视频写了一个简单的增删改查的,完成了最简单的一些功能,使用了三层架构。
dao层完成的是对数据库具体的功能实现,service层调用了dao层的实现方法,具体对servlet提供支持。
&
- 高手问答:Java老A带你全面提升Java单兵作战能力!
ITeye管理员
java
本期特邀《Java特种兵》作者:谢宇,CSDN论坛ID: xieyuooo 针对JAVA问题给予大家解答,欢迎网友积极提问,与专家一起讨论!
作者简介:
淘宝网资深Java工程师,CSDN超人气博主,人称“胖哥”。
CSDN博客地址:
http://blog.csdn.net/xieyuooo
作者在进入大学前是一个不折不扣的计算机白痴,曾经被人笑话过不懂鼠标是什么,