全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 python论坛
3617 8
2015-04-28
q.datayes.com来源: https://app.wmcloud.com/mercury/ ... 443f9f06c276f651a52
“谁来给我讲讲Python?”

作为无基础的初学者,只想先大概了解一下Python,随便编个小程序,并能看懂一般的程序,那些什么JAVA啊、C啊、继承啊、异常啊通通不懂怎么办,于是我找了很多资料,写成下面这篇日记,希望以完全初学者的角度入手来认识Python这个在量化领域日益重要的语言

一,熟悉基本

在正式介绍python之前,了解下面两个基本操作对后面的学习是有好处的:

1)基本的输入输出 可以在Python中使用+、-、*、/直接进行四则运算。












1



1+3*3













10



(2)导入模块 使用import可以导入模块,导入之后,就可以使用这个模块下面的函数了。 比如导入math模块,然后使用math模块下面的sqrt函数:












1



import math

2



math.sqrt(9)













3.0



这时我有疑问了:

“每次引用函数的时候,math这个模块前缀都要带吗?可不可以不带?”

直接输入sqrt(9)是会报错的,好烦人,那么有什么办法可以不用每次都带前缀?办法是有的,用“from 模块 import 函数”的格式先把函数给“拿”出来。












1



from math import sqrt

2



sqrt(9)













3.0



这样每次使用sqrt函数的时候就不用再加math前缀了。当我正准备跳过的时候,又有了一个问题?

“math模块下面有那么多函数,可不可以写一个语句,然后math下面所有函数都可以直接使用?”

调用了math下面的sqrt函数,写一个from…import…,再调用下面的floor,还要写一个,如此也挺麻烦的,有个办法可以一下把所有函数都给“拿”出来:












1



from math import *

2



print sqrt(9)

3



print floor(32.9)













3.0
32.0



二,容器

1,什么是容器

开始学Python时,被它的数据结构,什么字典、序列、元组等等搞的很混乱,估计有跟我一样的初学者,所以我梳理了一下留存: 首先要从容器说起,Python中有一种名为容器的数据结构,顾名思义,容器,就是装数据的器具,它主要包括序列和词典,其中序列又主要包括列表、元组、字符串等(见下面那张图)。

列表的基本形式比如:[1,3,6,10]或者[‘yes’,’no’,’OK’]

元组的基本形式比如:(1,3,6,10)或者(‘yes’,’no’,’OK’)

字符串的基本形式比如:’hello’

以上几种属于序列,序列中的每一个元素都被分配一个序号——即元素的位置,也称为“索引”,第一个索引,即第一个元素的位置是0,第二个是1,依次类推。列表和元组的区别主要在于,列表可以修改,而元组不能(注意列表用中括号而元组用括号)。序列的这个特点,使得我们可以利用索引来访问序列中的某个或某几个元素,比如:












1



a=[1,3,6,10]

2



a[2]













6











1



b=(1,3,6,10)

2



b[2]













6
invalid syntax (line 2)











1



c='hello'

2



c[0:3]













'hel'



而与序列对应的“字典”则不一样,它是一个无序的容器,

它的基本形式比如:d={7:'seven',8:'eight',9:'nine'}

这是一个“键—值”映射的结构,因此字典不能通过索引来访问其中的元素,而要根据键来访问其中的元素:












1



d={7:'seven',8:'eight',9:'nine'}

2



d[8]













'eight'



2、序列的一些通用操作

除了上面说到的索引,列表、元组、字符串等这些序列还有一些共同的操作。

(1)索引(补充上面)

序列的最后一个元素的索引,也可以是-1,倒数第二个也可以用-2,依次类推:












1



a=[1,3,6,10]

2



print a[3]

3



print a[-1]













10
10



(2)分片

使用分片操作来访问一定范围内的元素,它的格式为:

a[开始索引:结束索引:步长]

那么访问的是,从开始索引号的那个元素,到结束索引号-1的那个元素,每间隔步长个元素访问一次,步长可以忽略,默认步长为1。












1



c='hello'

2



c[0:3]













'hel'



这个就好像把一个序列给分成几片几片的,所以叫做“分片”




(3)序列相加

即两种序列合并在一起,两种相同类型的序列才能相加












1



[1,2,3]+[4,5,6]













[1, 2, 3, 4, 5, 6]
invalid syntax (line 2)











1



'hello,'+'world!'













'hello,world!'



(4)成员资格

为了检查一个值是否在序列中,可以用in运算符












1



a='hello'

2



print 'o' in a

3



print 't' in a













True
False
invalid syntax (line 2)



3、列表操作

以上是序列共有的一些操作,列表也有一些自己独有的操作,这是其他序列所没有的

(1)List函数

可以通过list(序列)函数把一个序列转换成一个列表:












1



list('hello')













['h', 'e', 'l', 'l', 'o']



(2)元素赋值、删除

元素删除——del a[索引号]

元素赋值——a[索引号]=值












1



a













'hello'











1



b=list(a)

2



b













['h', 'e', 'l', 'l', 'o']











1



del b[2]

2



b













['h', 'e', 'l', 'o']











1



b[2]='t'

2



b













['h', 'e', 't', 'o']



分片赋值——a[开始索引号:结束索引号]=list(值)

为列表的某一范围内的元素赋值,即在开始索引号到结束索引号-1的区间几个元素赋值,比如,利用上面语句,如何把hello变成heyyo?












1



b=list('hello')

2



b













['h', 'e', 'l', 'l', 'o']











1



b[2:4]=list('yy')

2



b













['h', 'e', 'y', 'y', 'o']



注意虽然“ll”处于“hello”这个单词的第2、3号索引的位置,但赋值时是用b[2:4]而不是b[2:3],另外注意list()用小括号。





q.datayes.com来源: https://app.wmcloud.com/mercury/ ... 443f9f06c276f651a52




二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2015-4-30 02:25:56
thanks.. looking forward to more...
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-5-4 10:08:14
thanks 4 sharing
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-5-7 01:01:40
不错哟,要是能整理一下排版就更好了
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-5-10 20:20:52
不错,赞一个~
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-5-12 12:47:23
怎么拿金币啊  我想下载点儿东西
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群