首先我们要说明的是本文不扯什么大道理,只是先介绍Python的背景,然后从实用的角度出发举一两个真实栗子。

首先要想了解要一门语言的好坏,或者为什么招程序员喜欢(卧槽,原来程序员喜欢不是女朋友?)我们的先从语言的产生背景开始,比如:他出现在什么年代,为了解决什么问题而出现的等。当然我也只是跟其他语言做一个比较,不讨论谁好谁坏,再说语言也没有什么好坏之分,就算有好坏之分,也得从实际应用场景出发,所有我们不讨论这个问题。

好,好,大兄弟你们都消消气,上面我扯的太多了,下面直接上重点...

1. Question

首先还是按照惯例,上来几个问题,这样能让初学者一目了然,有个大概的认识

1.1 Python是什么

是一种面向对象、解释型计算机程序设计语言,由Guido van Rossum于1989年圣诞节为打发无聊时间,而开发的一个新的脚本解释程序,可以感觉下什么叫牛人,是ABC语言的一种继承,至于为什么选中Python作为语言名字,是因为他是一叫Monty Python的喜剧团体的爱好者,第一个公开发行版发行于1991年。

他的设计哲学是

优雅

明确

简单

完全的面向对象。函数,模块,数字,字符串都是对象,不想Java中还有基本类型,在Python中一切皆对象,那作为程序员的我们害怕找到对象吗,直接New一个呀,呵呵

1.2 人们为什么用Python

这个问题往往是入门者第一个问题,对此我在一本书找到了这样的解答:

1.软件质量

2.开发这效率

3.程序的可移植性

4.众多标准库支持

5.组件集成

6.享受乐趣

其他的不用多讲,需要详细了解的可以搜索下,我只是提供大家几个方面让大家了解,因为往往对于初学者,是迷茫的,因为不支持从什么方向去了解一个事物,而我就是提供方向的,具体的大家可以自己去了解。我只说下最后一个,详细的可以参考下这篇文章每个程序员都应该学习使用 Python或Ruby文章里面也说的很明白,我总结几点就是

代码量小

维护成本低

编程效率高

同一样问题,用不同的语言解决,代码量差距太多了,一般情况下python是java的1/5,所以说人数苦短,我用python,多留点时间泡妹子吧,不然就老了

1.3 Python是脚本语言吗

·

他是一种多用户语言,至于为什么大家的第一感觉是脚本语言,我是因为人们看他的他直接写一个文件,不需要什么编译,跟脚本似得,直接运行的就行了。所以说我也很难给你一个确定答案,我就举一些常见的应用场景:

脚本:可以写一些辅助自己开的脚本,就比如,Android开发,会涉及到一常用的命令,但是如果是在windows用bat写,这样弄到mac就没法运行的,所以可以用,python写。另外如果你是服务器管理员,那么python脚本很适合你,程序长了用bash写,你会砸电脑的

网站开发:他有强大的Django,Flask框架

科学计算:有Numpy和Matlab一样强的数值计算接口

图形界面程序开发:这个不用多解释,就是常见的那种界面啦

2. Python版Hello World

通常任何一门语言都有一个hello world的过程,呵呵,所以说我们这里也一样,因为通过他你会学习到该语言的一个最基本的程序框架和运行过程,这对应初学者才是最重要的。

既然前面也说了,可以把他当脚本语言,那我们就来个最简单的,操作步骤如下:

在你的工作目录下创建一个hello.py文件,别问我你不知道工作目录是什么,那你该学学计算机基础了

在该文件里写入

print 'hello world'

3.     打开命令行,输入:

python hello.py

顺利的话你会看到hello world的输出,是不是感觉好简单,对,你没看错,就这么简单,现在你可以说你是一个python程序员了,呵呵~

3. Example

这里就举一个我最近实际应用中的例子,是什么呢,施主莫急,听平僧慢慢到来。场景是这样的最近一个日记软件本身的客户端不能用了,但是数据在sqlite数据库里呀,我们的需求是将里面的一些数据导出为txt文件,怎么这需求简单吧

3.1 Python

首先用python来解决这个问题,据跟上面的描述,我们很清楚的想到如下步骤:

连接sqlite3数据库

执行查询语句

打开文件

将查询的接口写入的刚刚打开的文件中

关闭数据

关闭文件

呵呵,我有想到了,让程序员把大象放到冰箱的故事了,可以参考这篇文章拖放三部曲——从“把大象放进冰箱”说起

好了,不废话了,直接上代码

#!/usr/bin/python# -*- coding: cp936 -*-import sqlite3import HTMLParserimport codecsimport time

f=codecs.open('note.txt','a',"utf-8") #以追加方式打开一个文件conn = sqlite3.connect('note.db') #打开sqlite数据库print "Opened database successfully";#执行查询语句,返回一个cursorcursor = conn.execute("select created,weather,address,latitude,longitude,content from tb_notescontents,tb_notes where tb_notescontents.note_guid=tb_notes.guid")#遍历每一行for row in cursor:    #取出改行的每一列

created= row[0]

weather= row[1]

address= row[2]

latitude= row[3]

longitude= row[4]

content= row[5]

html_parser = HTMLParser.HTMLParser()

d = time.localtime(created/1000)

currentTime = time.strftime('%Y-%m-%d %H:%M:%S',d)    #因为原理的内容是经过html转义了,所以要转回来,形如:今天,

weather = html_parser.unescape(weather)

address = html_parser.unescape(address)

content = html_parser.unescape(content)

f.write(currentTime) #写入文件

f.write('              ')

f.write(weather)

f.write('              ')

f.write(address)

f.write('              ')

f.write(content)

f.write('/n')

f.write('/n')

f.write('/n')

conn.close() ## 关闭数据库f.close() #关闭文件print "Operation done successfully";

至于逻辑,我在上面步骤也写的很清楚了,另外程序也谢了很详细的注释,所以说就算你不懂python也能很容易的看懂。

可以看到我们大概只用了50行代码就完成了,这个小需求,但是如果用Java是什么结果呢

3.2 Java

首先的我们的找一个开发工具,就eclipse吧。创建一个项目,然后添加一个TestMan.java

工程结构如下:

在TestMan.java中写一个基本的程序框架

public class TestMain {    public static void main(String[] args) {

}

}

卧槽,这么麻烦,搞了半天才把架子搭好,说实话Java确实中规中矩,干什么你都得按照他的那一套来,所以说呢,我们就不能直接贴代码了,步骤还得细分了,啥?

连接sqlite3数据库

通过JDBC连接:但是因为jdbc(Java Data Base Connectivity,java数据库连接)是java连接数据库的一套抽象设计API,既然是抽象的所以是不能直接使用,要找到他的实现,既然是连接sqlite所以应该去sqlite官网或者从bitbucket这里下载,我下载的版本是sqlite-jdbc-3.8.11.2,下载完后将他放到eclipse的环境变量里,下载才把准备工作做完,下面才开始写代码

执行查询语句

打开文件

将查询的接口写入的刚刚打开的文件中

关闭数据

关闭文件

现在我们直接上代码了

import java.io.BufferedWriter;import java.io.FileWriter;import java.io.IOException;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import org.apache.commons.lang3.StringEscapeUtils;public class TestMain {    public static void main(String[] args) {        // load the sqlite-JDBC driver using the current class loader

Connection connection = null;

BufferedWriter bufferedWriter = null;        try {

Class.forName("org.sqlite.JDBC");            // create a database connection

connection = DriverManager.getConnection("jdbc:sqlite:note.db");

Statement statement = connection.createStatement();

statement.setQueryTimeout(30); // set timeout to 30 sec.

ResultSet rs = statement

.executeQuery("select created,weather,address,latitude,longitude,content from tb_notescontents,tb_notes where tb_notescontents.note_guid=tb_notes.guid");

bufferedWriter = new BufferedWriter(                    new FileWriter("note.txt", true));            while (rs.next()) {                // read the result set

String created = rs.getString("created");

String weather = rs.getString("weather");

String address = rs.getString("address");

String latitude = rs.getString("latitude");

String longitude = rs.getString("longitude");

String content = rs.getString("content");                // write to file

bufferedWriter.write(created); // 写入文件

bufferedWriter.write("              ");

bufferedWriter.write(weather);

bufferedWriter.write("              ");

bufferedWriter.write(address);

bufferedWriter.write("              ");                // 转义html,可以看到我们又引用了commons-lang jar包

content = StringEscapeUtils.unescapeHtml4(content);

bufferedWriter.write(content);

bufferedWriter.newLine();

}

} catch (SQLException e) {            // if the error message is "out of memory",

// it probably means no database file is found

System.err.println(e.getMessage());

} catch (Exception e) {            // TODO Auto-generated catch block

e.printStackTrace();

} finally {            try {                if (connection != null)

connection.close();

} catch (SQLException e) {                // connection close failed.

System.err.println(e);

}            try {                if (bufferedWriter != null) {

bufferedWriter.close();

}

} catch (IOException e) {                // TODO Auto-generated catch block

e.printStackTrace();

}

}

}

}

现在大家可以看见了java和python的区别了吧,在java中什么功能也提供了,但是得引用各种jar,还得到处找去搜索或下载啦,各种肯爹,不过在python中很多常用库已经内置了,所以省去了很多麻烦,所以说以我个人感觉,python个适合解决工作中的一些小问题,当然大问题也是么有问题的啦~,文章到此基本结束了,当然我也没有偏袒那一面,另外我也是只是从我的工作或学习中得到的一些小领悟特此总结此处,如果大家有什么好的见解欢迎评论吐槽~

大数据培训、人工智能培训、Python培训、大数据培训机构、大数据培训班、数据分析培训、大数据可视化培训,就选光环大数据!光环大数据,聘请专业的大数据领域知名讲师,确保教学的整体质量与教学水准。讲师团及时掌握时代潮流技术,将前沿技能融入教学中,确保学生所学知识顺应时代所需。通过深入浅出、通俗易懂的教学方式,指导学生更快的掌握技能知识,成就上万个高薪就业学子。

更多问题咨询,欢迎点击------>>>>在线客服!

为什么不用python做大数据_光环大数据告诉你为什么说:人生苦短,我用Python相关推荐

  1. hadoop 光环大数据_光环大数据

    光环大数据高薪就业培训班,让你120天月薪轻松过万!准备好了吗?<光环大数据高薪就业班>课程介绍:本课程主要包含6大核心部分,分别是JavaSE课程.JavaEE课程.并发编程.Linux ...

  2. python做数学计算器_从零开始学习PYTHON3讲义(二)把Python当做计算器

    <从零开始PYTHON3>第二讲 上一讲我们说过了如何启动Python IDLE集成开发学习环境,macOS/Linux都可以在命令行执行idle3.Windows则从开始菜单中去寻找ID ...

  3. 一步一步教你如何用python做词云_一步一步教你如何用Python做词云

    前言 在大数据时代,你竟然会在网上看到的词云,例如这样的. 看到之后你是什么感觉?想不想自己做一个? 如果你的答案是正确的,那就不要拖延了,现在我们就开始,做一个词云分析图,Python是一个当下很流 ...

  4. python做pca图_【教程】组学研究,用python快速实现PCA分析和绘图

    什么是PCA 主成分分析(Principal Component Analysis,PCA)是一种无监督的多元统计分析方法.在蛋白组学和代谢组学研究中能从总体上反应各组样本之间的总体差异和组内样本之间 ...

  5. python有什么含金量高的证书排行_光环大数据分享18张含金量最高的大数据证书...

    光环大数据人工智能培训认为,不管你是基础不牢固没有开发经验的小白,还是有工作经验还想不断提升自己的开发者们,对于想在这个行业有发展,并付诸了实际努力的人,在这样一个发展前景下,未来都是有无限可能的.但 ...

  6. 算命数据_未来的数据科学家或算命精神向导

    算命数据 Real Estate Sale Prices, Regression, and Classification: Data Science is the Future of Fortune ...

  7. python怎么做彩票概率_小白学数据小抄放送 Python,R,大数据,机器学习

    原标题:小白学数据小抄放送 Python,R,大数据,机器学习 大数据文摘作品,转载要求见文末 作者 | Elaine,田桂英,Aileen 导读:前段时间小白学数据专栏出了一期Python小抄表,后 ...

  8. python 做交易软件下载_利用python下载股票交易数据

    原博文 2017-02-06 22:45 − 前段时间玩Python时无意看到了获取股票交易数据的tushare模块,由于自己对股票交易挺有兴趣,加上现在又在做数据挖掘工作,故想先将股票数据下载到数据 ...

  9. python数据处理电脑配置_『大数据python计算机基础教学视频教程』入门学python需要什么配置的电脑...

    x = 1 if x 4.2 1) else匹前的缩进相同且最接近的if 2) 改之前y=x 2行,之后是y=x 1先执行 第5题 代码还n = 1 while n <= 5: i = 1 wh ...

最新文章

  1. js ZeroClipboard 拷贝文本到剪贴板
  2. 三代测序纠错软件汇总篇
  3. oracle 071,Oracle_071_lesson_p3
  4. 上海应用技术学院c语言实验报告9,上海工程技术大学C语言实验报告
  5. uclinux多线程应用-网络通信[转]
  6. 网络规划设计(项目类业务)
  7. springCloud - 第6篇 - 网关的实现:ZUUL
  8. 关于ajax请求后台获取下拉列表用的数据
  9. php获得6个月以前的日期,请问下使用PHP如何获取某个月的所有日期
  10. MVC教程第七篇:闲话ASP.NET
  11. Docker的常用操作
  12. Python_字符串
  13. msm8953抓取audio kernel dsp log
  14. ensprip引入静态路由_IP路由基础理论知识详解(三)
  15. Silverlight 操作Excel 中的进程资源释放问题(续)
  16. 【codeforce 219D】 Choosing Capital for Treeland (树形DP)
  17. matlab接触封装,MATLAB如何解除封装
  18. Windows10+VS2019+OpenGL安装配置详解
  19. 19年绝响,张国荣「复活」!AI高清修复《热·情》燃爆2000万观众
  20. InputStream输入流七牛上传图片

热门文章

  1. RabbitMQ端口作用整理
  2. 抓住互联网平台红利期才能让网络营销事半功倍
  3. jToken与JArray简单笔记
  4. 名片设计的意义及分类
  5. php云虚拟主机建论坛,虚拟主机可以建论坛吗
  6. [插件]_AVPro Video插件-点击按钮播放相应视频
  7. 视频绿幕抠像应用:用FastDeploy部署RVM拯救视频剪辑师的发量
  8. PHP云软件短信接口,php调用云片网接口发送短信的实现方法
  9. 网站漏洞扫描工具AWVS相关问题——Access Denied for your user role. Contact your Administrator.
  10. 特征筛选方法--卡方检验