热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

量化分析师的Python日记【第1天:谁来给我讲讲Python?】

量化分析师的Python日记【第1天:谁来给我讲讲Python?】薛昆Kelvin优矿001号员工2015-01-2815:4858144克隆###“谁来给我讲讲Python?”作

量化分析师的Python日记【第1天:谁来给我讲讲Python?】薛昆Kelvin 优矿 001 号员工2015-01-28 15:48

 
144

###“谁来给我讲讲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()用小括号。

(3)列表方法

上面说过list函数,函数这个东西在很多语言中都有,比如excel里面的if函数、vlookup函数,SQL里面的count函数,以及各种语言中都有的sqrt函数等等,python中也有很多函数。 Python中的方法,是一个“与某些对象有紧密联系的”函数,所以列表方法,就是属于列表的函数,它可以对列表实现一些比较深入的操作,方法这样调用:

对象.方法(参数)

那么列表方法的调用就理所当然是:

列表.方法(参数)

常用的列表方法这么几个,以a=[‘h‘,‘e‘,‘l‘,‘l‘,‘o‘]为例:

 
 
 
 
 
1
a=[‘h‘,‘e‘,‘l‘,‘l‘,‘o‘]
2
a
 
 
[‘h‘, ‘e‘, ‘l‘, ‘l‘, ‘o‘]

给列表a的n索引位置插入一个元素m: a.insert(n,m)

 
 
 
 
 
1
a.insert(2,‘t‘)
2
a
 
 
[‘h‘, ‘e‘, ‘t‘, ‘l‘, ‘l‘, ‘o‘]

给列表的最后添加元素m: a.append(m)

 
 
 
 
 
1
a.append(‘q‘)
2
a
 
 
[‘h‘, ‘e‘, ‘t‘, ‘l‘, ‘l‘, ‘o‘, ‘q‘]

返回a列表中,元素m第一次出现的索引位置: a.index(m)

 
 
 
 
 
1
a.index(‘e‘)
 
 
1

删除a中的第一个m元素: a.remove(m)

 
 
 
 
 
1
a.remove(‘e‘)
2
a
 
 
[‘h‘, ‘t‘, ‘l‘, ‘l‘, ‘o‘, ‘q‘]

将列表a从大到小排列: a.sort()

 
 
 
 
 
1
a.sort()
2
a
 
 
[‘h‘, ‘l‘, ‘l‘, ‘o‘, ‘q‘, ‘t‘]

4、字典操作

(1)dict函数

dict函数可以通过关键字参数来创建字典,格式为:

dict(参数1=值1,参数2=值2, …)={参数1:值1, 参数2=值2, …}

比如,如何创建一个名字name为jiayounet,年龄age为28的字典?

 
 
 
 
 
1
dict(name=‘jiayounet‘,age=27)
 
 
{‘age‘: 27, ‘name‘: ‘jiayounet‘}

(2)基本操作

字典的基本行为与列表在很多地方都相似,下面的例子以序列a=[1,3,6,10],字典f={‘age‘: 27, ‘name‘: ‘shushuo‘}为例

技术分享

日记小结: 今天学习了Python的基本页面、操作,以及几种主要的容器类型,天还要学习Python的函数、循环和条件、类,然后才算是对Python有一个大致的了解。

量化分析师的Python日记【第1天:谁来给我讲讲Python?】


推荐阅读
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了如何使用python从列表中删除所有的零,并将结果以列表形式输出,同时提供了示例格式。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • 本文介绍了使用postman进行接口测试的方法,以测试用户管理模块为例。首先需要下载并安装postman,然后创建基本的请求并填写用户名密码进行登录测试。接下来可以进行用户查询和新增的测试。在新增时,可以进行异常测试,包括用户名超长和输入特殊字符的情况。通过测试发现后台没有对参数长度和特殊字符进行检查和过滤。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
author-avatar
六九四四708
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有