numpy,scipy,matlabplotlib,pandas学习笔记

numpy参考:https://scipy.github.io/old-wiki/pages/Tentative_NumPy_Tutorial

  1. 直接赋值是引用,改变 新变量值会改变原变量值。
    使用c = a.view()是建立了一个a的观测值变量,改变c也会改变a。
    要完全赋值使用深拷贝d = a.copy()
  2. numpy中可以直接用多维索引来建立一个多维array。但注意,不能将多个array作为索引,此时可以用tuple(多个array)将多个array转换成一个tuple

scipy参考:https://docs.scipy.org/doc/scipy/reference/tutorial/

  1. r_连接二维行 c_连接二维列。
    a = np.r_[3,[0]5,-1:1:10j]*
    其中10j的意思是铸造10个分割点
  2. mgrid铸造标准网格,类似matlab的meshgrid;ogrid返回的是多个一维的网格向量。
  3. vectorize(函子)传入函子,返回一个向量化的函数
  4. select函数的 意思通过下面这个例子说明:
 x = np.r_[-2:3]
 x
array([-2, -1,  0,  1,  2])
np.select([x > 3, x >= 0], [0, x+2],999) 
array([999, 999, 2, 3, 4])

也就是说x来进行判断,满足第一个条件就被0替换,满足第二个条件被x+2替换,如果都不满足就被999替换。
而where函数有两种用法:
np.where([[True, False], [True, True]],
... [[1, 2], [3, 4]],
... [[9, 8], [7, 6]])
array([[1, 8],
[3, 4]])
满足条件取第一个,不满足取第二个
第二种用法:只有一个输入参数,那么就返回True

matlabplotlib参考:https://nbviewer.jupyter.org/github/jrjohansson/scientific-python-lectures/blob/master/Lecture-4-Matplotlib.ipynb

  1. 注意Matplotlib所用的都是()而不是[].
  2. 可以使用latex格式,但要在

label=r"y = \alpha^3"
注意要加r来区分和python变量str区别。

注意plot和subplot的属性名:

属性名 简写 功能 备注
label="curve1" 线标签 最后要加ax.legend();
苹果 $1 6 6
草莓 $1 7 6

a.

ax.plot(x, x2, label="curve1")
ax.plot(x, x
3, label="curve2")
label="curve1"线标签
ax.legend(loc=0) # let matplotlib decide the optimal location
ax.legend(loc=1) # upper right corner
ax.legend(loc=2) # upper left corner
ax.legend(loc=3) # lower left corner
ax.legend(loc=4) # lower right corner

b.

ax.plot(x, x+13, color="purple", lw=1, ls='-', marker='o', markersize=2)
ax.plot(x, x+14, color="purple", lw=1, ls='-', marker='o', markersize=4)
ax.plot(x, x+15, color="purple", lw=1, ls='-', marker='o', markersize=8, markerfacecolor="red")
ax.plot(x, x+16, color="purple", lw=1, ls='-', marker='s', markersize=8,
markerfacecolor="yellow", markeredgewidth=2, markeredgecolor="blue");
lw是linewidth,ls是linestyle线形状,marker是点型

c. 决定坐标范围

fig, axes = plt.subplots(1, 3, figsize=(12, 4))

axes[0].plot(x, x2, x, x3)
axes[0].set_title("default axes ranges")

axes[1].plot(x, x2, x, x3)
axes[1].axis('tight') #(自决定)
axes[1].set_title("tight axes")

axes[2].plot(x, x2, x, x3)
axes[2].set_ylim([0, 60])
axes[2].set_xlim([2, 5])
axes[2].set_title("custom axes range");

d. 坐标指数

fig, axes = plt.subplots(1, 2, figsize=(10,4))

axes[0].plot(x, x**2, x, np.exp(x))
axes[0].set_title("Normal scale")

axes[1].plot(x, x**2, x, np.exp(x))
axes[1].set_yscale("log")
axes[1].set_title("Logarithmic scale (y)");

  1. 改变图像风格:
    plt.style.use('ggplot')
    可以先使用
    print(plt.style.available)
    查看图像风格

sns.lmplot(x='total_bill', y='tip', data=tips, col='sex')
col,row将不同的分类点画在不同画布上;hue='sex'将分类点画在同一画布上,但标出不同颜色。
6.二变量画图法:
sns.jointplot(x='hp',y='mpg',data=auto,kind='resid')

kind='scatter' uses a scatter plot of the data points
kind='reg' uses a regression plot (default order 1)
kind='resid' uses a residual plot
kind='kde' uses a kernel density estimate of the joint distribution
kind='hex' uses a hexbin plot of the joint distribution
  1. 多变量画图:
    注意,传入的都要是dataframe
    sns.pairplot(data)非常简单
    sns.heatmap(cov_matrix)相关性的图

pandas参考:http://pandas.pydata.org/pandas-docs/stable/tutorials.html

  1. 注意深拷贝berri_bikes = bikes[['Berri 1']].copy()一定要用copy,注意bikes后有两个中括号
  2. rows_with_dashes = requests['Incident Zip'].str.contains('-').fillna(False)
    fillna的含义是充填缺失值
  3. daily_temp_2011 = daily_mean_2011['dry_bulb_faren'].values
    .values让一个series(pandas)转换成了array(numpy)
    pandas内容太多了,建议还是直接看官方cookbook
  4. 一列写入的时候,要用双[],否则会当做series没有列名。列选择都要加双[],即
    data[['rnd_1', 'rnd_3']]
    也就是说从dataframe里面选出列名的那些列作为dataframe要加双括号

sklearn

  1. transform() 和fit_transform()区别:https://blog.csdn.net/quiet_girl/article/details/72517053

tranform()的作用是通过找中心和缩放等实现标准化
fit_transform()的作用就是先将数据拟合模型,然后转化它将其转化为标准形式

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 什么是NumPy? NumPy is the fundamental package for scientific...
    黑人不是牙膏阅读 6,577评论 1 3
  • 一.NumPy的引入 标准安装的Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列...
    wlj1107阅读 999评论 0 2
  • 先决条件 在阅读这个教程之前,你多少需要知道点python。如果你想从新回忆下,请看看Python Tutoria...
    舒map阅读 2,563评论 1 13
  • 来源:NumPy Tutorial - TutorialsPoint 译者:飞龙 协议:CC BY-NC-SA 4...
    布客飞龙阅读 32,660评论 6 96
  • 浩如烟海的佛经常使人望而却步、叹为观止。然如何使千年传承之经典为忙碌于现代生活的人们掌握并受用,以至于得到...
    传统文化精华阅读 1,198评论 4 3