欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python基于network模塊制作電影人物關(guān)系圖

 更新時間:2020年06月19日 08:39:58   作者:夏日的向日葵  
這篇文章主要介紹了Python基于network模塊制作電影人物關(guān)系圖,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

在我們生活的世界中,每一個人以及每一個事物相互之間都存在著關(guān)系,有直接關(guān)系,也有間接關(guān)系,最終會形成一個無形的大的關(guān)系網(wǎng)。network模塊是一個用python語言開發(fā)的圖論和復雜網(wǎng)絡(luò)建模工具,模塊內(nèi)置了常用的圖與復雜網(wǎng)絡(luò)分析算法。

network模塊有四種圖:Graph、DiGraph、MultiGraph、MultiDigraph,分別為無多重邊無向圖、無多重邊有向圖、有多重邊無向圖、有多重邊有向圖。其中Graph是用點和線來刻畫離散事物集合中,每對事物間以某種方式相聯(lián)系的數(shù)學模型。

下面我們來分析《復仇者聯(lián)盟4》人物關(guān)系:

import pandas as pd
#導入繪圖模塊
import networkx as nx
import matplotlib.pyplot as plt
# 讀取文件
aa =r'F:\\python入門\\python編程錦囊\\Code(實例源碼及使用說明)\\Code(實例源碼及使用說明)\\Code(實例源碼及使用說明)\\09\\data\\fl4.xls'
df = pd.DataFrame(pd.read_excel(aa))
#去除重復項,并轉(zhuǎn)換成列表
df1=df['label1'].drop_duplicates().values.tolist()
df2=df[['label1','label2','weight']]
#設(shè)置畫布大小
plt.figure(figsize=(6, 5))
#顏色數(shù)據(jù)
colors = df['color'].drop_duplicates().values.tolist()
#G:圖表,一個networkx圖
G = nx.Graph()
# 添加邊
for i in df2.index:
  G.add_edge(df2.label1[i], df2.label2[i], weight=df2.weight[i])
# 定義兩個邊,并給邊賦予權(quán)重,其中u是起點,v是終點,d是權(quán)重
edge1 = [(u, v) for (u, v, d) in G.edges(data=True) if (d['weight'] >=1)]
edge2 = [(u, v) for (u, v, d) in G.edges(data=True) if (d['weight'] >=15)]
# 圖的布局
# 節(jié)點在一個圓環(huán)上均勻分布
pos = nx.circular_layout(G)
#用Fruchterman-Reingold算法排列節(jié)點
#pos=nx.spring_layout(G)
#節(jié)點隨機分布
#pos=nx.spring_layout(G)
# 點
#node_size指定節(jié)點的尺寸大小,默認值為300
#node_color指定節(jié)點的顏色,默認值為紅色
#node_shape節(jié)點的形狀,默認值為圓形,用o表示
nx.draw_networkx_nodes(G, pos, alpha=1, node_size=200,node_color=colors,node_shape='o')
#nx.draw_networkx_nodes(G, pos, alpha=1, node_size=300,node_color=colors,node_shape='p')
# 邊
#pos:字典類型,節(jié)點作為鍵、位置作為值。位置是長度為2的序列
#edgelist:邊緣元組的集合,只繪制指定的邊,默認值為G.edges()
#width邊的寬度,默認值為1.0
#alpha透明度,默認值為1.0(不透明),0為完全透明
#edge_color邊的顏色,默認值為黑色
#style邊的樣式,默認值為實線。
nx.draw_networkx_edges(G, pos, edgelist=edge1,width=1, alpha=0.3, edge_color='g', style='dashed')
nx.draw_networkx_edges(G, pos, edgelist=edge2, width=1.5, alpha=0.5, edge_color='red')
# 標簽
#font_size節(jié)點標簽字體大小,默認值為12
nx.draw_networkx_labels(G, pos, font_size=9)
# 生成結(jié)果
plt.axis('off')
plt.title('《復仇者聯(lián)盟4》人物關(guān)系圖')
plt.rcParams['font.size'] = 10
plt.rcParams['font.sans-serif']=['SimHei'] #解決中文亂碼
plt.show()

結(jié)果:

使用力引導算法Fruchterman-Reingold排列點畫圖,可以大大減少邊的交叉,只需要改兩行代碼即可:

#用Fruchterman-Reingold算法排列節(jié)點
pos=nx.spring_layout(G)
# 點
nx.draw_networkx_nodes(G, pos, alpha=1, node_size=300,node_color=colors,node_shape='p')

結(jié)果:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python實現(xiàn)的簡單萬年歷例子分享

    Python實現(xiàn)的簡單萬年歷例子分享

    這篇文章主要介紹了Python實現(xiàn)的簡單萬年歷例子分享,需要的朋友可以參考下
    2014-04-04
  • pyqt5 獲取顯示器的分辨率的方法

    pyqt5 獲取顯示器的分辨率的方法

    今天小編就為大家分享一篇pyqt5 獲取顯示器的分辨率的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • python實現(xiàn)線性插值的示例

    python實現(xiàn)線性插值的示例

    線性插值是針對一維數(shù)據(jù)的插值方法,它根據(jù)一維數(shù)據(jù)序列中需要插值的點的左右臨近兩個數(shù)據(jù)來進行數(shù)值估計,這篇文章主要介紹了python實現(xiàn)線性插值,需要的朋友可以參考下
    2022-12-12
  • tensorflow 實現(xiàn)打印pb模型的所有節(jié)點

    tensorflow 實現(xiàn)打印pb模型的所有節(jié)點

    今天小編就為大家分享一篇tensorflow 實現(xiàn)打印pb模型的所有節(jié)點,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • python爬蟲獲取多頁天涯帖子

    python爬蟲獲取多頁天涯帖子

    本篇文章通過爬取多頁天涯帖子內(nèi)容來教給大家深入理解python爬蟲相關(guān)知識,有興趣的參考學習下。
    2018-02-02
  • python實現(xiàn)plt x軸坐標按1刻度顯示

    python實現(xiàn)plt x軸坐標按1刻度顯示

    這篇文章主要介紹了python實現(xiàn)plt x軸坐標按1刻度顯示,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • python正則表達式re模塊詳解

    python正則表達式re模塊詳解

    re 模塊包含對正則表達式的支持,因為曾經(jīng)系統(tǒng)學習過正則表達式,所以基礎(chǔ)內(nèi)容略過,直接看 python 對于正則表達式的支持。
    2014-06-06
  • python神經(jīng)網(wǎng)絡(luò)pytorch中BN運算操作自實現(xiàn)

    python神經(jīng)網(wǎng)絡(luò)pytorch中BN運算操作自實現(xiàn)

    這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)pytorch中BN運算操作自實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • python獲取柵格點和面值的實現(xiàn)

    python獲取柵格點和面值的實現(xiàn)

    這篇文章主要介紹了python獲取柵格點和面值的實現(xiàn),具有很好的參考價值,希望對大家有多幫助。一起跟隨小編過來看看吧
    2020-03-03
  • python 實現(xiàn)倒排索引的方法

    python 實現(xiàn)倒排索引的方法

    今天小編就為大家分享一篇python 實現(xiàn)倒排索引的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12

最新評論