楼主: ookiddy
2590 3

[源码分享] 【量化实验室q.datayes.com】量化分析师的Python日记【第1天:谁来给我讲讲Python?】 [推广有奖]

  • 0关注
  • 3粉丝

高中生

62%

还不是VIP/贵宾

-

威望
0
论坛币
847 个
通用积分
0
学术水平
9 点
热心指数
9 点
信用等级
9 点
经验
2426 点
帖子
17
精华
0
在线时间
23 小时
注册时间
2006-8-24
最后登录
2022-12-20

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

原文地址 q.datayes.com


谁来给我讲讲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


二维码

扫码加我 拉你入群

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

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

关键词:python Data 量化分析 实验室 Yes 实验室 python import 分析师 初学者

已有 2 人评分经验 论坛币 收起 理由
fantuanxiaot + 50 + 50 精彩帖子
jerker + 24 精彩帖子

总评分: 经验 + 50  论坛币 + 74   查看全部评分

本帖被以下文库推荐

沙发
wangluan 发表于 2015-5-2 09:35:04 |只看作者 |坛友微信交流群
这个社区不错,收藏了

使用道具

藤椅
ng4517 发表于 2015-5-2 12:12:23 |只看作者 |坛友微信交流群
有个不错的在线教程, 可以边学边练http://www.codecademy.com/tracks/python

使用道具

板凳
gangsinli 发表于 2015-6-19 22:47:37 |只看作者 |坛友微信交流群
最近正在研究

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注jr
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-19 14:12