为何说”人生苦短,我用python“?

本文不扯什么大道理,只是先介绍Python的背景,而后从实用的角度出发举一两个真实栗子。html

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

好,好,大兄弟大家都消消气,上面我扯的太多了,下面直接上重点…python

1. Question

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

1.1 Python是什么程序员

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

他的设计哲学是数据库

优雅
明确
简单
彻底的面向对象。函数,模块,数字,字符串都是对象,不想Java中还有基本类型,在Python中一切皆对象,那做为程序员的咱们惧怕找到对象吗,直接New一个呀,呵呵apache

1.2 人们为何用Python编程

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

软件质量
开发这效率
程序的可移植性 
众多标准库支持 
组件集成 
享受乐趣
其余的不用多讲,须要详细了解的能够搜索下,我只是提供你们几个方面让你们了解,由于每每对于初学者,是迷茫的,由于不支持从什么方向去了解一个事物,而我就是提供方向的,具体的你们能够本身去了解。我只说下最后一个,详细的能够参考下这篇文章每一个程序员都应该学习使用 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'

打开命令行,输入:

python hello.py

顺利的话你会看到hello world的输出,是否是感受好简单,对,你没看错,就这么简单,如今你能够说你是一个python程序员了,呵呵~

3. Example

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

3.1 Python

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

链接sqlite3数据库
执行查询语句
打开文件
将查询的接口写入的刚刚打开的文件中
关闭数据
关闭文件

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

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

#!/usr/bin/python
# -*- coding: cp936 -*-

import sqlite3
import HTMLParser
import codecs
import time

f=codecs.open('note.txt','a',"utf-8") #以追加方式打开一个文件

conn = sqlite3.connect('note.db') #打开sqlite数据库

print "Opened database successfully";

#执行查询语句,返回一个cursor
cursor = 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个适合解决工做中的一些小问题,固然大问题也是么有问题的啦~,文章到此基本结束了,固然我也没有偏袒那一面,另外我也是只是从个人工做或学习中获得的一些小领悟特此总结此处,若是你们有什么好的看法欢迎评论吐槽~

原文连接:

https://blog.csdn.net/woblog/article/details/51051809

-END-


  识别图中二维码,领取python全套视频资料

相关文章
相关标签/搜索