zoukankan      html  css  js  c++  java
  • python 入门1

    python的历史

    Python是一种解释型、面向对象、动态数据类型的高级程序设计语言。

    Python由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年。

    像Perl语言一样, Python 源代码同样遵循 GPL(GNU General Public License)协议。

    python的简介

    Python 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。

    Python 的设计具有很强的可读性,相比其他语言经常使用英文关键字,其他语言的一些标点符号,它具有比其他语言更有特色语法结构。

    python 是一种解释性语言,交互性语言,面向对象的语言,初学者的语言

    python的特点

    易于学习 ,易于阅读 ,易于维护

    互动模式,便携式 ,可扩展

    数据库,GUI编程,可扩展性 

    一个广泛的标准库

    python 下载

    Python最新源码,二进制文档,新闻资讯等可以在Python的官网查看到:

    Python官网:http://www.python.org/

    你可以在一下链接中下载Python的文档,你可以下载 HTML、PDF 和 PostScript 等格式的文档。

    Python文档下载地址:www.python.org/doc/

    python 安装

    linux系统自带python

    分别为centos和xubuntu  

    xubuntu14.10

    centos6.5
    1. [root@git learn]# python
      Python2.6.6(r266:84292,Jan222014,09:42:36)
      [GCC 4.4.720120313(RedHat4.4.7-4)] on linux2
      Type"help","copyright","credits"or"license"for more information.
      >>>
       
      

        

    python升级 

    centos6.5 默认安装的是python2.6.6 

    首先

    关闭防火墙

    1. chkconfig iptables off 
      service  iptables stop  
      

        

    禁止selinux

    1. vim /etc/selinux/config 
      改为: SELINUX=disabled 
      [root@git ~]# setenforce 0 
       
      

        

    epel源

    1. wget http://download.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
      rpm -ivh epel-release-6-8.noarch.rpm
      

        

    时间同步
    1. crontab -e  
      ntpdate 202.120.2.101
      151***/usr/sbin/ntpdate 202.120.2.101;/usr/sbin/hwclock -w >/dev/null 2>&1   
       
      

        

     1 编译安装

    1. yum install -y zlib-devel bzip2-devel openssl-devel xz-libs wget curl  gcc openssh openssh-clients python-devel gcc-c++ automake swig libsodium
              
      wget --no-check-certificate https://www.python.org/ftp/python/2.7.10/Python-2.7.10.tgz     
      wget  http://mirrors.sohu.com/python/2.7.8/Python-2.7.10.tgz  (国内源 比较快) 
      tar xf Python-2.7.10.tgz 
      cd Python-2.7.10
      ./configure  --prefix=/usr/local/yoho/python2.7.10
      make && make install
      

        

    2 脚本安装解决yum源问题
    1. #!/bin/bash 
      yum install -y zlib-devel bzip2-devel openssl-devel xz-libs wget curl  gcc openssh openssh-clients python-devel gcc-c++ automake swig libsodium openssh openssl 
      #--------------------------------------python-------------------------------
      wget  http://mirrors.sohu.com/python/2.7.8/Python-2.7.10.tgz
      tar xf Python-2.7.10.tgz-C /opt 
      cd /opt
      cd Python-2.7.10
      ./configure  --prefix=/usr/local/yoho/python2.7.10
      make && make install
      [  $?==0   ]&& echo "successful"|| exit 1 
      #---------------------------------------yum---------------------------------
      mv /usr/bin/python  /usr/bin/python-old 
      ln -s /usr/local/yoho/python2.7.10/bin/python /usr/
      py_version=`python -V` 
      sleep 1
      py_yum=`sed -n  "/^#/p"/usr/bin/yum | cut -d /-f 4`
      [ ${py_yum}=="python2.6"]&& echo "yum is ok"  && exit 0
      sed -i s@#!/usr/bin/python@#!/usr/bin/python2.6@  /usr/bin/yum
      yum list>/dev/null 
      [  $?==0   ]&& echo "successful"|| exit 4
      echo "yum is ok."
      

        

     

    首先当然是  python 彩蛋 

    1. >>>importthis
      TheZen of Python, by TimPeters
      Beautiful is better than ugly.
      Explicit is better than implicit.
      Simple is better than complex.
      Complex is better than complicated.
      Flat is better than nested.
      Sparse is better than dense.
      Readability counts.
      Special cases aren't special enough to break the rules.
      Although practicality beats purity.
      Errors should never pass silently.
      Unless explicitly silenced.
      In the face of ambiguity, refuse the temptation to guess.
      There should be one-- and preferably only one --obvious way to do it.
      Although that way may not be obvious at first unless you're Dutch.
      Now is better than never.
      Although never is often better than *right* now.
      If the implementation is hard to explain, it's a bad idea.
      If the implementation is easy to explain, it may be a good idea.
      Namespaces are one honking great idea -- let's do more of those!
      >>> 
      

        

    八荣八耻
    
     
    
    以动手实践为荣,以只看不练为耻。 
    以打印日志为荣,以单步跟踪为耻。 
    以空白分隔为荣,以制表分隔为耻。 
    以单元测试为荣,以手工测试为耻。 
    以代码重用为荣,以复制粘贴为耻。 
    以多态应用为荣,以分支判断为耻。 
     以Pythonic为荣,以冗余拖沓为耻。 
    以总结思考为荣,以不求甚解为耻。
    

      

     

    先来个复杂的  python终端介绍

    1. >>>if2>1:            
      ...     print "2 da yu 1 "  #python默认缩进4个空格
      ...else:                    #跟shell不一样的地方 每个判断语句关键词后面加 :
      ...     print "2 xiao yu 1" #打印输入用print
      ...  #python的次提示符
      2 da yu 1 #输出的结果
      >>>  #python的提示符
      python 第一个程序
      >>> print "hello world "
      hello world 
      >>> 
      

        

     

    python执行过程 

     
     

    解释器 

    如果想要像shell脚本一样执行python需要在python脚本文件的开头指定解释器 
    root@bds:/Data/project/oneday# vim hello.py 
    root@bds:/Data/project/oneday# vim hello.py 
        #!/usr/bin/env python                               #在文件的开头并顶头写
        print "hello world"
    root@bds:/Data/project/oneday# chmod 755 hello.py       #赋予执行的权限
    root@bds:/Data/project/oneday# python hello.py 
    hello world
     
    

      

    编码风格

    ASCII  :(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。
    显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode
     
    Unicode:(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,

    注:此处说的的是最少2个字节,可能更多

    UTF-8 : 是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...

    gbk 和utf-8的不同 

     

    GBK编码:是指中国的中文字符,其它它包含了简体中文与繁体中文字符,另外还有一种字符“gb2312”,这种字符仅能存储简体中文字符。

    UTF-8编码:它是一种全国家通过的一种编码,如果你的网站涉及到多个国家的语言,那么建议你选择UTF-8编码。

    GBK和UTF8有什么区别?

    UTF8编码格式很强大,支持所有国家的语言,正是因为它的强大,才会导致它占用的空间大小要比GBK大,对于网站打开速度而言,也是有一定影响的。

    GBK编码格式,它的功能少,仅限于中文字符,当然它所占用的空间大小会随着它的功能而减少,打开网页的速度比较快。

    gbk和utf-8的转换关系

     


    操作

    1. >>>"步"
      'xb2xbd'                                    #现在是gdk编码
      >>> str1 ='xb2xbd'                          #赋值变量
      >>> str1.decode("gbk")                        #解码
      u'u6b65'                                     #u 最前面u代表unicode 已经解码为unicode
      >>> a = str1.decode("gbk").encode("utf-8")    # 一步操作 再把unicode编码为utf-8
      >>>print a                                    # 打印a出来 如下是一个utf-8编码的字
      姝
       
      

        

    显示中文

    1. #!/usr/bin/env python
      # -*- coding:uft-8 -*-                #加上编码注释 避免出错 固定格式
      print "你好 ,世界"
      这样就可以打印中文 ,为了避免忘记 ,以后再编程过程中 ,要默认添加
      

        

       python 注释 

    # ooxx                 单行注释
    """ ooxx """ 多行注释
    #! /usr/bin/env python #coding=utf-8 """this is input hello world""" print "hello world"                  #intut something root@bds:/Data/project/learn# python helloworld.py hello world root@bds:/Data/project/learn
     

    python  变量


     
    a = r'
    '      #输出原型打印
    a = u'中文'     #定义为unicode编码
    global  a      # 定义a为全局变量
     

    python  数据类型 

        数据类型的组成 
        1 身份ID : id(a) 唯一标识符 每一个数据的标识符都是不一样的
        2 类型  :    type(a)
        3 值  :  
        python 里面一切都是指针
     
     

    常用的数据类型

    字符串             #str
    布尔类型           #bool
    整数               #int
    浮点数             #float
    列表               #list
    元组               #tuple
    字典               #dict
     
     
     
     
     
     
     
     





    本文是纯属个人学习理解,如有遗漏误导,请大神果断指正......
  • 相关阅读:
    ガリレオの苦悩 攪乱す 1
    magento -- 添加中国省份列表
    magento使用google analytics
    Magento导出订单同时导出产品信息
    如何修改WAMP数据库上传文件的大小及上传时间限制
    magento插件手动下载
    Magento的价格去掉小数点
    magento首页调用最新产品
    url重写技术
    magento添加分类属性
  • 原文地址:https://www.cnblogs.com/budongshu/p/1ceadb16fb0bccb6e281d0b4cdaf7e3d.html
Copyright © 2011-2022 走看看