笨方法,高效率

2024-04-21 05:48
文章标签 方法 高效率

本文主要是介绍笨方法,高效率,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(更好的排版请见 http://liyasong.farbox.com/post/ben-fang-fa-,gao-xiao-lu)

笨方法,高效率,并非是指笨方法本身效率高,而是指遇到问题时,通过自我思考解决问题,可以在比较短的时间内想到一种笨方法,使得不用依赖网络搜索和资料,进而可以确保自己在可以预计的时间内解决问题。经常练习如此,便可在解决问题上达到思维方式的灵活转变,收获高效率。

一个简单的例子

我在写FPTree算法时,使用linux下的split命令将一个transaction.txt文件分成了10个分区文件“transaction.aa~ transaction.aj”,而我想得到这样的文件命名“transaction.00~ transaction.09”。我去研究split命令的参数,看能不能直接分割文件后输出以数字结尾的文件名,无功而返。我又去研究mv命令的参数,希望能直接使用一次mv修改所有的文件名成想要的名字,也是无功而返。当然这期间,我会上网搜索有没有相关的解决方案。而最后我的解决方法是:在编辑器sublime text2里写一条mv transaction.aa transaction.00,然后复制到10行,手动将a替换成相应字母,再将0替换成相应数字,最后就是这样的效果。

mv transaction.aa transaction.00
mv transaction.ab transaction.01
mv transaction.ac transaction.02
mv transaction.ad transaction.03
mv transaction.ae transaction.04
mv transaction.af transaction.05
mv transaction.ag transaction.06
mv transaction.ah transaction.07
mv transaction.ai transaction.08
mv transaction.aj transaction.09

然后,我复制,再在linux终端下粘贴,运行,完成全部文件名字的修改,总耗时不超过30秒。我本想更加高效地解决问题,一个命令,一个函数就可以解决。甚至专门写一个函数处理,只要能不手动一条条处理即可。而事实上,即便我在终端下一条条地手写mv,也比上面的聪明方法花的时间都少,也不会超过2分钟。而上面的例子稍作改进,依然是使用笨方法,时间就已经不足半分钟了。

使用网络找答案,面临两个问题,一描述清自己的问题,二找到网上正确的答案。这两个问题真的很难,平时面对面与人交流描述生活的问题已经很难,每每遇到自己说了一堆,对方问:你说什么?此时涌起不是抽自己一大嘴巴就是赏对方一耳光的冲动。而在网上还要描述清技术问题,更是难中之难。比如程序员界经常唠叨的一个现象就是某程序员遇到了问题A,自己有解决思路B,但又遇到阻碍,然后各种向人咨询B相关问题,结果最终被问的某个人发现此程序员想解决的是问题A,然后他给出一个成功的解决方案C。在生活中,与人沟通的成本非常高,网络上,修正自己的问题和尝试所搜寻答案的对错,都有非常高的成本。我室友培总某日加班回来跟我们说:“今天公司上不了网,结果我一下午干了比前3天还多的活”。我想除了平时上网休闲的因素,这个现象也一定程度证明了自己解决问题比上网搜资料有效很多吧。捷径往往意味着更长的路,网络上可以找到解决你问题的答案就像一个可怕的走捷径的诱惑,因为它会让人习以为常。

在使用R语言工作的过程中,我还遇到了很多类似的例子。有过很多次教训,为我脑子里的设想的高效解决方案在网上各种一通找。甚至为同一个问题找过多次,最后却无功而返。而在我无心插柳的时候,比如看R某库的函数的demo时,发现其中某行代码正好是解决我之前遇到的某数据处理的一种简洁高效方法。有的问题的简洁高效方法可能就是一特殊函数,你知道它,你就能很快搞定问题。而有的简洁高效方法体现的是一种解决方式,你理解了它,相通的问题都能找到高效方法了。

R处理数据相关的两个例子

一是依次修改数据框的每一个变量

这个问题困难在于,我只能得到字符串类型的变量名,无法引用这个变量对象,使用的笨方法是,把交互代码打印出来,再去除"符号,把交互代码粘贴进去执行。
idvar都是字符串类型的变量名,执行下面代码

for (idvar in idvars)print(paste("base.dpi.equal$",idvar,"<-","as.factor(","base.dpi.equal$",idvar,")")

得到

"base.dpi.equal$USER_ID <- as.factor( base.dpi.equal$USER_ID )"
"base.dpi.equal$ACCT_BRAND_ID <- as.factor( base.dpi.equal$ACCT_BRAND_ID )"
"base.dpi.equal$AGE_ID <- as.factor( base.dpi.equal$AGE_ID )"
"base.dpi.equal$BRAND_ID <- as.factor( base.dpi.equal$BRAND_ID )"
"base.dpi.equal$CALL_COUNTS_ID <- as.factor( base.dpi.equal$CALL_COUNTS_ID )"
"base.dpi.equal$CALL_DURATION_M_ID <- as.factor( base.dpi.equal$CALL_DURATION_M_ID )"
"base.dpi.equal$CHANNEL_ID <- as.factor( base.dpi.equal$CHANNEL_ID )"

复制放到sublime text2里,替换掉"符号,得到下面的代码,粘贴到交互行执行

base.dpi.equal$USER_ID <- as.factor( base.dpi.equal$USER_ID )
base.dpi.equal$ACCT_BRAND_ID <- as.factor( base.dpi.equal$ACCT_BRAND_ID )
base.dpi.equal$AGE_ID <- as.factor( base.dpi.equal$AGE_ID )
base.dpi.equal$BRAND_ID <- as.factor( base.dpi.equal$BRAND_ID )
base.dpi.equal$CALL_COUNTS_ID <- as.factor( base.dpi.equal$CALL_COUNTS_ID )
base.dpi.equal$CALL_DURATION_M_ID <- as.factor( base.dpi.equal$CALL_DURATION_M_ID )
base.dpi.equal$CHANNEL_ID <- as.factor( base.dpi.equal$CHANNEL_ID )

使用这些笨方法虽然代码量大,但并不耗时,主要是粘贴复制和字符串处理的功夫。我好几次不想使用这个笨方法,又跑到网上找,跑到论坛问,问如何将字符串转化为变量之类,答案很少,找到的也都不好使。这又耗费我的宝贵的时间,验证拖慢了我的工作节奏。直到我无意中在某函数demo里发现相关代码。最后上面的问题有了个简洁的方法。

#将字符串转化为表达式执行,解决了字符串不能作为变量名的问题
for (idvar in idvars)exp = parse(text=paste("base.dpi.equal$",idvar,"<-","as.factor(","base.dpi.equal$",idvar,")") #将字符串转化为表达式执行eval(exp)     #执行表达式

二是依次读取数据框的每一个变量

前面的解决方案已经可以修改数据库,读取自然不在话下。我开始一段时间使用都是循环打印的方法,而实际上,读取数据量的每一个变量可以十分十分简洁。

#查看一个数据框的各变量是否有缺失值
sapply(product, f <- function(x){ return(sum(is.na(x))})
#sapply函数就是对第一个参数(数据框)的每一个变量依次应用第二个参数(f函数)

这些问题我在网上都找过,并非网上没有这些问题的答案,而是当我还不够熟悉R语言中处处体现着向量整体运算思维,避免循环思想时,我是很难描述清我的问题的,而即便我看到相近的答案,我也很可能依葫芦画瓢地使用却没能奏效。同样地,如果别人不理解那些思想,即便知道那些简洁的方案,也很可能回答不好我的问题。所以,我的教训是当未到掌握聪明方法的时机时,不要强求,不是所有为了寻找好的解决方案而上网搜索花费的时间都是值得的。

笨方法思维并非是要专门思考需要手动处理较多的方法,而是‘在工作中可以不依赖资料帮助,遇到问题时可以独立快速地找到解决方案,使得工作的流畅度不受影响’的一种思维方式,它的确容易在条件或知识受限的情况下使用一些看似较笨的方法。有段时间我是一个特别喜欢使用新工具,新方法的人,看到别人还在使用某些旧工具旧方法时不免惊讶,还像别人推荐新工具和方法。现在想想,真是可笑,我只看到别人工具和方法的落后,却看不到别人高效完成工作背后的原因。好的工具方法可以提高单位时间的效率,笨方法思维也许才是保证流畅的工作节奏的原因。新工具方法的使用不过是工作中顺其自然的事。

这篇关于笨方法,高效率的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922288

相关文章

Python中__init__方法使用的深度解析

《Python中__init__方法使用的深度解析》在Python的面向对象编程(OOP)体系中,__init__方法如同建造房屋时的奠基仪式——它定义了对象诞生时的初始状态,下面我们就来深入了解下_... 目录一、__init__的基因图谱二、初始化过程的魔法时刻继承链中的初始化顺序self参数的奥秘默认

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

Spring 基于XML配置 bean管理 Bean-IOC的方法

《Spring基于XML配置bean管理Bean-IOC的方法》:本文主要介绍Spring基于XML配置bean管理Bean-IOC的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录一. spring学习的核心内容二. 基于 XML 配置 bean1. 通过类型来获取 bean2. 通过

基于Python实现读取嵌套压缩包下文件的方法

《基于Python实现读取嵌套压缩包下文件的方法》工作中遇到的问题,需要用Python实现嵌套压缩包下文件读取,本文给大家介绍了详细的解决方法,并有相关的代码示例供大家参考,需要的朋友可以参考下... 目录思路完整代码代码优化思路打开外层zip压缩包并遍历文件:使用with zipfile.ZipFil

Python处理函数调用超时的四种方法

《Python处理函数调用超时的四种方法》在实际开发过程中,我们可能会遇到一些场景,需要对函数的执行时间进行限制,例如,当一个函数执行时间过长时,可能会导致程序卡顿、资源占用过高,因此,在某些情况下,... 目录前言func-timeout1. 安装 func-timeout2. 基本用法自定义进程subp

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

电脑死机无反应怎么强制重启? 一文读懂方法及注意事项

《电脑死机无反应怎么强制重启?一文读懂方法及注意事项》在日常使用电脑的过程中,我们难免会遇到电脑无法正常启动的情况,本文将详细介绍几种常见的电脑强制开机方法,并探讨在强制开机后应注意的事项,以及如何... 在日常生活和工作中,我们经常会遇到电脑突然无反应的情况,这时候强制重启就成了解决问题的“救命稻草”。那