一.基本数据类型

1.整形 

a=10
type(a)
Out[75]: int a.bit_length() #字节长度
Out[76]: 4 整形相除会返回整形,想要返回浮点数,需要用浮点数相除
1./4
Out[79]: 0.25

  

2.浮点型

b=0.25
type(b)
Out[80]: float 浮点数表示成有理分式

 b.as_integer_ratio()
  Out[81]: (1, 4)

那么怎么确定精度呢? 需要引入decimal模块

import decimal
 from decimal import Decimal

decimal.getcontext()
 Out[82]: Context(prec=8, rounding=ROUND_HALF_EVEN, Emin=-999999, Emax=999999, capitals=1, clamp=0, flags=[Inexact, Rounded], traps=[InvalidOperation, DivisionByZero, Overflow])

可以看到 精度是28,还有最大值、最小值
可以改变精度

decimal.getcontext().prec=4 # 改变精度为4

e=Decimal(1)/Decimal(11)  #计算1/11
  print(e)

输出结果:
 0.09091

确定精度为10:

decimal.getcontext().prec=10

e=Decimal(1)/Decimal(11)
 print(e)

0.09090909091

3.字符串

字符串表示文本

t='this is a string'

t.capitalize()
Out[88]: 'This is a string'

按tab键可以有自动补全功能,可以查看内建方法。比如:图中有字符串的一些内建方法,capitalize等。

t.split()  #字符串的分割
Out[23]: ['this', 'is', 'a', 'string'] #结果分割为列表 查找

 t.find('a')  #查找元素‘a’,返回元素位置,注意:python位置下标从0开始
 Out[25]: 8

 替换

t.replace(' ','|')  #把空格替换为‘|’
 Out[27]: 'this|is|a|string'

去除操作

s='http://wwww.python.org'
 s.strip('htp:/') #去除'htp:/'
 Out[29]: 'wwww.python.org'

正则表达式 re的简单应用

import re

series="""
'01/18/2014 13:00:00',100,'1st',   #三引号表示可以换行
'01/18/2014 13:00:00',110,'2nd',
'01/18/2014 13:00:00',120,'3rd',
"""

dt=re.compile(r"'[0-9/:\s]+'")  #匹配规则:反斜杠表示转译
result=dt.findall(series)
print(result)

["'01/18/2014 13:00:00'", "'01/18/2014 13:00:00'", "'01/18/2014 13:00:00'"] #返回值是一个列表

接着把时间序列转化为datetime对象

from datetime import datetime

pydt=datetime.strptime(result[0].replace("'",""),'%m/%d/%Y %H:%M:%S')
pydt

Out[102]: datetime.datetime(2014, 1, 18, 13, 0)

type(pydt)

Out[103]: datetime.datetime

小注:

datetime模块的时间与字符串转化:

import datetime
from datetime import datetime

datetime.datetime.strftime():由日期格式转化为字符串格式

datetime.datetime.now().strftime('%m-%d-%Y %H:%M:%S')

Out[105]: '05-02-2018 18:27:58'

datetime.datetime.strptime():由字符串格式转化为日期格式

datetime.datetime.strptime('05-16-2017 21:01:35', '%m-%d-%Y %H:%M:%S')
Out[107]: datetime.datetime(2018, 5, 2, 18, 27, 58)

具体参考:https://www.cnblogs.com/cindy-cindy/p/6720196.html

二.基本数据结构

1.元组:tpule

t=(1,2.5,'date')

t1=1,2.5,'date'
type(t1)
Out[3]: tuple t1[2]
Out[4]: 'date'

只有两个方法 : 计数与下表返回索引
t.count(para)
t.index(para)

t.count(1)
Out[6]: 1 t.index(1)
Out[7]: 0

2.列表

列表的构建

l=[1,2,1.5]
l1=[x for x in range(10)]
l2=list(t)
print(l,'\n',l1,'\n',l2)
[1, 2, 1.5]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[1, 2.5, 'date']

操作方法:

print('abc\ndef')  #\n  换行
abc
def type(l1)
Out[10]: list l.append([4,3]) #添加列表
l
Out[11]: [1, 2, 1.5, [4, 3]] l.extend([1,3,6]) # 添加元素
l
Out[12]: [1, 2, 1.5, [4, 3], 1, 3, 6] l.insert(1,'date')
l
Out[13]: [1, 'date', 2, 1.5, [4, 3], 1, 3, 6] l.remove('date')
l Out[14]: [1, 2, 1.5, [4, 3], 1, 3, 6] p=l.pop(2) # pop 方法 可用返回值接受
print(l,'\n',p) [1, 2, [4, 3], 1, 3, 6]
1.5 l[:2]
Out[16]: [1, 2]

3.字典

d={
'name':'John',
'sex':'male',
'age':18,
'country':'China'}
d['name']
Out[17]: 'John' d.keys() # 所有key组成的列表
Out[18]: dict_keys(['name', 'sex', 'age', 'country']) d.values()
Out[19]: dict_values(['John', 'male', 18, 'China']) d.items() # 字典转化为 list list中元素是元组,元组由字典的key 和balue组合
Out[20]: dict_items([('name', 'John'), ('sex', 'male'), ('age', 18), ('country', 'China')]) print('{} is {}'.format(d['name'],d['age']))
John is 18 birth=True if birth is True:
d['age']+=1 print(d['age'])
19

  

字典的遍历

for i in d:
print(i) name
sex
age
country
for item in d.items():
print(item) ('name', 'John')
('sex', 'male')
('age', 19)
('country', 'China')
for values in d.values():
print(values) John
male
19
China

4.集合

s=set(['u','i','du','du','u'])    

print(s)   

t=set(['du','u'])
t
{'i', 'u', 'du'}
Out[27]: {'du', 'u'}

交并补

s.union(t)
Out[29]: {'du', 'i', 'u'} s.intersection(t)
Out[30]: {'du', 'u'} s.difference(t)
Out[31]: {'i'}

5. 函数编程

简单的函数:

def f(x):
return x**2 f(2)
Out[32]: 4  

求偶数:

def even(x):
return x%2==0 even(2)
Out[33]: True

  

map函数:
 python3下的map()函数返回类型为iterators,不再是list

map()的使用方法形如map(f(x),Itera).对,它有两个参数,第一个参数为某个函数,第二个为可迭代对象。

list(map(even,range(4)))
Out[34]: [True, False, True, False] list(map(lambda x:x**2,range(4))) Out[35]: [0, 1, 4, 9]

filter 函数:

过滤功能,刷选出符合条件的

list(filter(even,range(15)))
Out[36]: [0, 2, 4, 6, 8, 10, 12, 14]

reduce函数:
 reduce()的使用方法形如reduce(f(x),Itera).对,它的形式和map()函数一样。不过参数f(x)必须有两个参数。reduce()函数作用是:把结果继续和序列的下一个元素做累积计算

from functools import reduce
reduce(lambda x,y:x+y,range(5)) Out[37]: 10

其实就是类似下边的函数:

def cunsum(x):
total=0
for i in range(x):
total+=i
return total cunsum(5)
Out[38]: 10

python金融应用(二)基本数据类型和结构的更多相关文章

  1. python基础(二)-------数据类型

    python开发基础篇(二)数据类型 python数据类型有: 1.数字 1.只能存放一个值 2.一经定义,不可更改 3.直接访问 主要的分类为:整型,长整型,(python2有长整型的概念Pytho ...

  2. Python系列:二、数据类型--技术流ken

    标准数据类型 Python3 中有六个标准的数据类型: Number(数字) String(字符串) List(列表) Tuple(元组) Set(集合) Dictionary(字典) Python3 ...

  3. python教程(二)·数据类型

    数据类型,顾名思义就是数据的类型,数据到底有哪些类型呢?在python中,最基本的数据类型有好几种,让我来逐个介绍. 整数类型(int) python中只有一种整数类型,就是int类型,在程序中的写法 ...

  4. Python基础(二)数据类型

    (一)数字 Python3中的数字类型分为3种,分别是整型,浮点型以及复数. Python2种的数字类型分为4种,分别是整型,长整型,浮点型以及复数. 其中长整型时Python2为应对位数较大的而设置 ...

  5. python学习(二)--数据类型

    数据类型 1.工厂函数 type() int() float() str() list() tuple() dict() bool() set()工厂函数的理解:工厂函数看上去有点像函数,实质上他们是 ...

  6. python开发基础(二)常用数据类型调用方法

    1 数字: int 2 3 int : 转换,将字符串转化成数字 4 num1 = '123' 5 num2 = int (a) 6 numadd = num2 +1000 7 print(num2) ...

  7. Redis之(二)数据类型及存储结构

    Redis支持五中数据类型:String(字符串),Hash(哈希),List(列表),Set(集合)及zset(sortedset:有序集合). Redis定义了丰富的原语命令,可以直接与Redis ...

  8. Python学习笔记(二)——数据类型

    1.数据类型 Python有五个标准的数据类型: Numbers(数字) String(字符串) List(列表) Tuple(元组) Dictionary(字典) 2.Python数字类型 Pyth ...

  9. Python 数据分析(二 本实验将学习利用 Python 数据聚合与分组运算,时间序列,金融与经济数据应用等相关知识

    Python 数据分析(二) 本实验将学习利用 Python 数据聚合与分组运算,时间序列,金融与经济数据应用等相关知识 第1节 groupby 技术 第2节 数据聚合 第3节 分组级运算和转换 第4 ...

  10. python基础二(基本数据类型)

    python的基本数据类型:数字.字符串.列表.元祖.字典.集合 一.基本数据类型 1.1 数字int 数字主要是用来计算用的,使用方法并不多. # bit_length() 当十进制用二进制表示的时 ...

随机推荐

  1. NioEventLoop的创建

    NioEventLoop的创建 NioEventLoop是netty及其重要的组成部件,它的首要职责就是为注册在它上的channels服务,发现这些channels上发生的新连接.读写等I/O事件,然 ...

  2. docker初解

    1 什么是容器 容器就是在隔离的环境中运行的一个进程,如果进程停止,容器就会退出. 隔离的环境拥有自己的系统文件,ip地址,主机名等 容器是一种软件打包技术 程序:代码,命令进程:正在运行的程序容器的 ...

  3. 使用CBrother的CLIB库调用windows的API

    使用CBrother的CLIB库调用windows的API 2.1.0版本CBrother加入了CLib库,最新需要写一个工具,根据路径查杀一个Windows进程,研究了一下,CLib库的用法,感觉还 ...

  4. CMDB连接方式

    1.agent agent (放在每台客户端服务器上,定时任务) 脚本演示 # 采集本机的信息 执行命令 import subprocess v1 = subprocess.getoutput('ip ...

  5. W与V模型的联系与区别

      很多小白一定要注意:        看准那个是开发的工作哪个是测试的工作,不要弄混了!!!   软件测试的V模型 以“编码”为黄金分割线,将整个过程分为开发和测试,并且开发和测试之间是串行的关系 ...

  6. VMware虚拟机Linux中增加磁盘空间的扩容操作

    VMwareware虚拟机安装的Red Hat Enterprise Linux系统剩余空间不足,造成软件无法正常安装.如果重新装一遍系统就需要重新配置好开发环境和软件的安装配置.结合自己的实践,总结 ...

  7. 力扣(LeetCode)环形链表 个人题解

    给定一个链表,判断链表中是否有环. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 -1,则在该链表中没有环. 示例 1: 输入: ...

  8. 遗忘root密码,应该如何修改?[CentOS7.5]

    https://www.lanzous.com/i71hw6d 下载视频演示 实验环境:VMware Workstation [CentOS7.5]遗忘root用户密码 应该如何修改??? 设置BIO ...

  9. 扛把子 选题 Scrum立会报告+燃尽图 03

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2019fall/homework/8680 一.小组情况组长:迟俊文组员:宋晓丽 梁梦瑶 韩昊 刘信鹏队名:扛 ...

  10. Spring(Bean)5

    spel <bean id="address" class="com.atguigu.spring.beans.spel.Address"> < ...