1、和C++、Java的区别:

  动态类型:不需要声明a的类型。

    a=34

    type(a)

    <type  ‘int’>

  一切皆对象:

    4

2、数字:

  自动转换类型:a=34

          A=3.14

         A=2**1000(2的1000次方)

         //——整除的意思

  Decimal:

    问题1:0.3*3=0.8999999999999

    解决办法1:print(0.3*3)

      输出0.9

    解决办法2:用decimal

      From decimal import Decimal as D

      D(‘0.3’)*D(3)

      输出:Decimal(‘0.9’)

    问题2:1/2**10000=0L

    原因:上边这么写会自动转换成整数,所以为0。

    错误改正:1.0/2**10000

    此时又超了范围,无法表示

    正确改正:D(1)/D(2**10000)

      输出:Decimal(‘5.0123727……E-3011’)

    decimal这么好的优点,可以计算许多。缺点是执行时间可能比较长。

    我们可以用python -s “python语句”的形式在控制页面中执行Python的单条语句。再加上-mtimeit可以统计1000或10000次里边计算最快的那次。

    例如:

    python -mtimeit -s “from decimal import Decimal as D”

    “D(‘1.2’)+D(‘3.4’)”与

    python -mtimeit -s “from decimal import Decimal as D”

    “1.2+3.4”的运行时间,发现Decimal 的运行时间比直接运行要慢很多。

常用库:

  Import math

  math.pi

  math.sqrt(80)

  math.log10(2**1000)

  math.pow((x,y)   求x的y次方

  math.factorial(x)   x的阶乘

  import random

  random.random()

  random.choice(1,2,3,4)  等概率的从中选一个

  random.randint(a,b)    a 到b的整数中的一个随机整数

  random.uniform(a,b)    a到b之间均匀分布的一个随机数

  Random.gaus(mu,lamda)   返回一个高斯分布的随机数

  使用help(math)可以返回所有的函数的用法。因为Python中一切皆对象,所以,写函数的时候要用点的形式调用(猜的)。

  random有什么用: 

    random.random()>0.8则中奖

  numpy 科学运算的库:产生数组或矩阵,正态分布的随机数矩阵运算,矩阵求逆

  scipy  科学计算的库,拟合,线性插值,样条插值 积分,微分,解非线性方程

3、字符串

  切片,索引

    s=”use python do something”

    s[1]   s中第二个字符

    s[-1]   s中最后一个字符

    s[1:3]   s中1-3的字符串

    s[1:6:2]    s中从1开始,到6结束,2是步长

    s[1:]     从1开始的到最终的所有字符

    s[:-1]    从开始到最后一个字符

    S[:]     表示所有

    split  把单词按照某种要求分隔开如split(‘ ’)会按照空格把单词分隔开

    join   和split区别,是把单词合并

    常用的方法集合

    “let us ”+s  把s加到let us后边

    s*2  两个s

    s.upper()   全部大写

    s.find(‘pa’)   找含有pa的字符

    s.replace(‘python’,’java’)      用java替换python

    print”%s like %s %”(‘we’,’python’)   用we和Python填到%s里边

    strip       是去掉两头的空格

  转义字符

    s=”C:\newpython”,print s,len(s)

    

解决方法: 

  r’   \n’前缀字符串,不考虑转义

  

  三个双引号”””,用在字符串中既有单引号又有双引号的情况。

Unicode u’ ‘

  可以显示各国语言,是一种编码方式,是一个字符集。如utf8是一种国际化的编码方式。如果只想支持国语:gb2312,建议大家都用utf8,会比较方便。

  

  

  写法 u’    ’

  

字符串-re模块

  import re

  Regular expression

  re.match(p,text)               从头开始找,其他地方不找,只返回一个

  re.search(p,text)               从开始找,其他地方也找,只返回一个

  re.findall(p,text)        返回多个,然后作为列表返回

  re.split(p,text)         分离

  re.sub(p,s,text)       替换

  实际步骤(提高性能):pattern=re.compile(p)

  result=pattern.match(text)

  正则表达式(太多了,需要好好记):

  举例

  

  

  

  

  

  

  ^是非,|是或,[^0-9]意思是不是数字,因为空格也不是数字,所以后边会跟了一串……

  贪婪模式*    +  尽可能匹配多

  非贪婪模式*?   +?    尽可能匹配的少

  

  

4、日期和时间

  datetime

    日期:datetime.date.today()

    日期和时间:datetime.datetime.now()

    1000天以后是哪一天 datetime.timedelta(day=1)

    打印格式:Isoformat(),strftime()

    

  time 

    datetime.time(12,11,30)   十二点十一分三十秒

    time.time()  实际时间,运行两次,然后求差

    time.clock()   cpu时间,运行两次,然后求差

    time.sleep()

5、列表

  类似于数组。

  >>> a=[1,2,3]

  >>> a_ref=a     a_ref是a的引用

  >>> a[2]=100

  >>> a

  [1, 2, 100]

  >>> a_ref

  [1, 2, 100]

  常用操作

       a_copy   a的拷贝

     a.append(300)  a的末尾加一个元素

     a.insert(1,50)   把50插到1这个位置上

     a.pop()    弹出来

     a.sort()   排序

     a.reverse()   反序

     del a[1]   删除1这个位置的元素

     嵌套,多个类型并存

      

      +与*

      

      

      a.count(1)对a中的1进行计数。

      列表属于变量,可以多次赋值;字符串是常量,不可以多次赋值

      

      

6、不可变列表——元组,用小括号()

  (a,b,c),不能修改

  常用操作:

    index

    count  对某个元素计数

    + *

    嵌套   可嵌套可变的list

    转换   tuple()   将一个list转换成元组

    

    转换完成元组的时候,引用某个元素还是要用[]完成,而不是()。

7、字典

  Key-Value

  dict={‘xiaoming’:90,’xiaohong’:80,’xiaomao’:60,’xiaoli’:54}  直接定义字典

  dict   每个字典都是一个对象,用它的构造函数生成一个字典

  zip  两个相同长度的列表生成一个字典,一个是key,一个是values

  

  常用操作

  keys,values

  get

  update    想里边加入

  del    删除

  clear   清空

  

  嵌套   关键字只能用不可变的类型,如数字,字母,元组等

  字典是散列表,没有顺序,适合插入查询操作,key不一定是字符串,但一定是个不可变的对象。字典是通过关键字访问元素,list使用index来访问元素。

  排序:

    方法1:[(k,dict[k])for k in sorted(eict.keys())]

    方法2:sorted(dict.iteritems(),key=lambda d:d[1],reverse=true)

   再谈引用和拷贝

    引用:字典直接用=,则是引用,拷贝需要专门的拷贝函数,这个与list不同。list的引用c=a,而赋值如d=a[:]

    

    

    

    浅拷贝:

      字典d.copy(),copy.copy(d)

      列表L[:]

    深拷贝:

      copy.deepcopy(d)

      如果只有一层的话,深拷贝和浅拷贝一样的,如果有多层,浅拷贝只拷贝一层。

8、文件

  f=open(path,’r’)返回对象为file-like object 还可以是内存、网络等,r是只读,w是只写,a是既可以读也可以写。

  f.read()   读出来一个字节或一个单位

  f.readline() 读出一行来,读到换行为止

  r.write() 写

  r.close()   关闭文件

  中文支持

    import codecs

    f=codecs.open(filename,mode,encoding)   encoding我们一般用的uft-8的模式

  文件操作

    import os

    os.path.exists(filename)  判断文件是否存在

     

    实际操作在IDLE中照样是乱码,如果在cmd中或者在IDLE中生成文件后再运行时不会乱码。

    shelve 库   (把书放到书架上)

      import shelve

      d=shelve.open(file)

      d[‘name’]=’heibanke’

      d.close()

      它只有一个函数open,是一个简单的数据存储方案,你可以用它来存储东西,可以当做一个字典。

      

      

      程序中‘d’并没有写进去,因为是d没有写回,你把[‘a’,’b’,’c’]存到x,当你再次读取s[‘x’]的时候,它又从源中读取了一个拷贝,解决办法是利用一个中间变量。

      

      

      注意的是,f如果没有关闭的话,将会赋值成空,关闭之后再赋值,结果与第一次的一样。

      pickle/cpickle  库  保存数据

      import cpickle

      f=open(file,mode)

      cpickle.dump(obj,f)

      obj=cpickle.load(f)

      

      其中:

         

      是一个元组。

python变量——黑板客老师课程学习的更多相关文章

  1. python类——黑板客老师课程学习

    1.基本语法 class class_name(base_class):  base_class是它继承的父类 class_var def methods(self,args): statements ...

  2. python爬虫——黑板客老师课程学习

    程序: 目标url 内容提取 表现形式 为什么: 大数据——数据膨胀,信息太多了,不知道哪些信息适合你,例如谷歌搜索引擎. 垂直行业搜索——某一个行业的搜索,与搜索引擎最大的区别:搜索引擎是告诉你哪些 ...

  3. python画图—黑板客老师课程学习

    1.介绍 把每个图都看作一个对象,图中的每一个部分也是对象.——所有的一切都是对象. 工具——ipython notebook 是python里边用的最多的2D&3D的会图库,开源免费库,使用 ...

  4. python计算机视觉——黑板客老师课程学习

    机器学习的一个应用方向,是如何让机器去理解图像.包括对图像里物体的识别,跟踪和测量. 能做什么——无人驾驶汽车.人脸识别.车牌识别手势识别(游戏方向) PIL静态的库 OpenCV 动态的库 impo ...

  5. 线性代数和numpy——黑板客老师课程学习

    一.代数是什么 代数->数的抽象表示->向量空间(线性空间) 线代->线性代数 关系: 向量空间之间和内部转换是通过线性变换. 实数——一维空间的点 复数——二维空间的点 如果两个向 ...

  6. python语句表达式——黑板客老师课程学习

    1.赋值 多重赋值: a,b=1,2 a,b=’beijing’,’sh’ a,b=’bj’ a,b=(1,2) a,b=[1,2] …… 2.输入输出 输入: raw_input()   原始输入 ...

  7. pyhton函数——黑板客老师课程学习

    1.基本语法 语法: def func_name (arguments)  定义 statements return x,y x,y=func_name(para)   调用 作用域: 可以给内置的函 ...

  8. "做中学"之“极客时间”课程学习指导

    目录 "做中学"之"极客时间"课程学习指导 所有课程都可以选的课程 Java程序设计 移动平台开发 网络攻防实践 信息安全系统设计基础 信息安全专业导论 极客时 ...

  9. Python 变量详解[学习 Python 必备基础知识][看此一篇就够了]

    您的"关注"和"点赞",是信任,是认可,是支持,是动力...... 如意见相佐,可留言. 本人必将竭尽全力试图做到准确和全面,终其一生进行修改补充更新. 目录 ...

随机推荐

  1. Altium Designer 画"差分线"

    Altium Designer 画"差分线" 如何在 Altium Designer 中快速进行差分对走线1:在原理图中让一对网络前缀相同,后缀分别为_N 和_P,并且加上差分队对 ...

  2. 《C与指针》第三章练习

    本章问题 1.What is the range for characters and the various integer types on your machine? (在你的机器上,字符型和整 ...

  3. spring技术核心概念纪要

    一.背景 springframework 从最初的2.5版本发展至今,期间已经发生了非常多的修正及优化.许多新特性及模块的出现,使得整个框架体系显得越趋庞大,同时也带来了学习及理解上的困难. 本文阐述 ...

  4. 035. asp.netWeb用户控件之四通过用户控件实现投票和结果分析

    用户控件Vote.ascx代码 <%@ Control Language="C#" AutoEventWireup="true" CodeFile=&qu ...

  5. Apache Shiro 使用手册(四)Realm 实现

    在认证.授权内部实现机制中都有提到,最终处理都将交给Real进行处理.因为在Shiro中,最终是通过Realm来获取应用程序中的用户.角色及权限信息的.通常情况下,在Realm中会直接从我们的数据源中 ...

  6. Mysql 存储过程+定时任务,完成分区自动维护

    建表: drop table if exists terminal_parameter; CREATE TABLE `terminal_parameter` ( `terminal_parameter ...

  7. Hadoop学习13--zookeeper相关

    zookeeper要保证各个server之间同步,实现同步的协议是zab协议.此协议有两种模式:恢复模式(选主)和广播模式(同步). 服务启动或者leader崩溃时,进入恢复模式.选举成功且大多数se ...

  8. metaspace之三--Metaspace解密

    概述 metaspace,顾名思义,元数据空间,专门用来存元数据的,它是jdk8里特有的数据结构用来替代perm,这块空间很有自己的特点,前段时间公司这块的问题太多了,主要是因为升级了中间件所致,看到 ...

  9. 使用chrome联调不在同一个域的请求

    做前端的,用Ajax获取数据,是常有的事情,同域下自然没问题了,如果是不同域获取数据,浏览器就有个同源策略的限制. Origin * is not allowed by Access-Control- ...

  10. HttpURLConnection 直接发送soap消息调用webservice

    httpConn = (HttpURLConnection) new URL(urlString).openConnection();    httpConn.setRequestProperty(& ...