主頁 > 後端開發 > 8-地圖可視化與seaborn可視化

8-地圖可視化與seaborn可視化

2023-06-07 07:40:38 後端開發

地圖可視化

basemap安裝和使用
區域縮放與繪圖
綜合案例:美國人口分布圖

seaborn可視化

樣式與分布圖
分類圖

basemap地圖繪制

地圖繪制也是資料可視化的一部分,常用的地圖繪制庫為basemap工具包,其為matplotlib的子包,本章將講解如何利用whl檔案在Python3環境下安裝basemap;學會使用basemap繪制地圖;學會縮放區域和繪制散點圖;通過綜合案例,鞏固basemap的繪制地圖方法和技巧,
本章主要涉及到的知識點有:

?basemap安裝:學會basemap的安裝方法,
?basemap使用:學會利用basemap繪制簡單地圖,
?縮放區域與繪圖:學會通過定位經緯度縮放區域與繪制散點圖,
?綜合案例:通過綜合案例,鞏固basemap的繪制地圖方法和技巧,

basemap的使用

basemap是一個強大的繪制地圖工具包,本節將講解如何安裝和使用basemap,結合matplotlib,繪制地圖,

basemap安裝

在anaconda的python3環境中,通過conda命令安裝basemap會導致失敗,這里通過該網站(https://www.lfd.uci.edu/~gohlke/pythonlibs/)
下載對應版本的Pyproj和basemap的whl檔案,如圖12.1和12.2所示,
image
圖12.1 Pyproj下載

image
圖12.2 basemap下載

在anaconda環境中,切換到這兩個whl檔案的路徑下,按順序通過pip依次安裝Pyproj和basemap檔案,代碼如下,安裝Pyproj,如圖12.3所示,代表Pyproj安裝成功,

h:
cd H:\python資料分析\資料
pip install pyproj-1.9.5.1-cp36-cp36m-win_amd64.whl

image
圖12.3 Pyproj安裝

以同樣的方法安裝basemap,代碼如下,如圖12.4所示,安裝basemap,

h:
cd H:\python資料分析\資料
pip install basemap-1.1.0-cp36-cp36m-win_amd64.whl

image
圖12.4 basemap安裝

如圖12.5所示,通過from mpl_toolkits.basemap import Basemap代碼呼叫該庫,發現程式可以運行,代表basemap庫安裝成功,
image
圖12.5 安裝成功

basemap使用

首先,匯入需要的第三方庫,通過basemap初始化一個地圖物件,通過drawcoastlines繪制海岸線,代碼如下,

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from mpl_toolkits.basemap import Basemap
%matplotlib inline

map1 = Basemap(projection='ortho', lat_0=90, lon_0=-105,
              resolution='l', area_thresh=1000.0)      #初始化地圖物件
map1.drawcoastlines()      #繪制海岸線

projection引數是用于定義地圖的投影方式;lat_0和lon_0是指定地圖的中心坐標,這里的值為美國的中心坐標;resolution引數設定繪制邊界的精度,l為低精度;area_thresh引數為閾值,低于該閾值的就不會被繪制,繪制地圖如圖12.6所示,注意:更多引數詳情可參考http://matplotlib.org/basemap/,
image
圖12.6 基本地圖
通過drawcountries方法繪制國家邊界,代碼如下,如圖12.7所示,

map1 = Basemap(projection='ortho', lat_0=90, lon_0=-105,
              resolution='l', area_thresh=1000.0) 
map1.drawcoastlines()  #繪制海岸線
map1.drawcountries()   #繪制國家

image
圖12.7 繪制國家

其他常見的繪制方法如下:

drawmapboundary()   #繪制邊界
drawstates()          #繪制州
drawcounties()        #繪制縣
通過fillcontinents方法為大陸填充顏色,代碼如下,如圖12.8所示,
map1 = Basemap(projection='ortho', lat_0=90, lon_0=-105,
              resolution='l', area_thresh=1000.0) 
map1.drawcoastlines()  #繪制海岸線
map1.drawcountries()   #繪制國家
map1.fillcontinents(color='blue',alpha=0.5)  #填充顏色

image
圖12.8 填充大陸顏色
通過drawmeridians和drawparallels方法繪制經線和緯線,代碼如下,如圖12.9所示,

map1 = Basemap(projection='ortho', lat_0=90, lon_0=-105,
              resolution='l', area_thresh=1000.0) 
map1.drawcoastlines()  #繪制海岸線
map1.drawcountries()   #繪制國家
map1.drawmapboundary() #繪制邊界
map1.fillcontinents(color='blue',alpha=0.5)  #填充顏色

map1.drawmeridians(np.arange(0, 360, 30))    #繪制經線
map1.drawparallels(np.arange(-90, 90, 30))   #繪制緯線

image
圖12.9 繪制經度和緯度
更換projection引數,換為robin坐標,可將圖繪制為平面坐標,代碼如下,如圖12.10所示,

map1 = Basemap(projection='robin', lat_0=90, lon_0=-105,
              resolution='l', area_thresh=1000.0) 
map1.drawcoastlines()  #繪制海岸線
map1.drawcountries()   #繪制國家
map1.drawmapboundary() #繪制邊界
map1.fillcontinents(color='blue',alpha=0.5)  #填充顏色

map1.drawmeridians(np.arange(0, 360, 30))    #繪制經線
map1.drawparallels(np.arange(-90, 90, 30))   #繪制緯線

image
圖12.10 平面坐標

縮放區域與繪圖

在實際案例中,需對特定國家或地區進行繪制地圖,這樣就需要通過llcrnrlon、llcrnrlat、urcrnrlon和urcrnrlat指定左下角經緯度和右上角經緯度,代碼如下,如圖12.11所示,

map2 = Basemap(projection='stere', lat_0=90, lon_0=-105,
               llcrnrlon=-118.67, llcrnrlat=23.41,
               urcrnrlon=-64.5, urcrnrlat=45.44,
              resolution='l', area_thresh=1000.0) 
map2.drawcoastlines()  #繪制海岸線
map2.drawcountries()   #繪制國家
map2.drawmapboundary() #繪制邊界
map2.drawstates()      #繪制州
map2.fillcontinents(color='blue',alpha=0.5)  #填充顏色

map2.drawmeridians(np.arange(0, 360, 30))    #繪制經線
map2.drawparallels(np.arange(-90, 90, 30))   #繪制緯線

image
圖12.11 縮放區域
通過坐標定位,可以在地圖上繪制圖形,代碼如下,如圖12.12所示,

map2 = Basemap(projection='stere', lat_0=90, lon_0=-105,
               llcrnrlon=-118.67, llcrnrlat=23.41,
               urcrnrlon=-64.5, urcrnrlat=45.44,
              resolution='l', area_thresh=1000.0) 
map2.drawcoastlines()  #繪制海岸線
map2.drawcountries()   #繪制國家
map2.drawmapboundary() #繪制邊界
map2.drawstates()      #繪制州
map2.drawmeridians(np.arange(0, 360, 30))    #繪制經線
map2.drawparallels(np.arange(-90, 90, 30))   #繪制緯線

lon = -74
lat = 40.43
x,y = map2(lon, lat)       #映射坐標
map2.plot(x, y, 'ro', markersize=8)  #繪制散點圖

image

圖12.12 繪制散點圖
通過matplotlib庫的text方法,為散點加入文本注釋,

map2 = Basemap(projection='stere', lat_0=90, lon_0=-105,
               llcrnrlon=-118.67, llcrnrlat=23.41,
               urcrnrlon=-64.5, urcrnrlat=45.44,
              resolution='l', area_thresh=1000.0) 
map2.drawcoastlines()  #繪制海岸線
map2.drawcountries()   #繪制國家
map2.drawmapboundary() #繪制邊界
map2.drawstates()      #繪制州

map2.drawmeridians(np.arange(0, 360, 30))    #繪制經線
map2.drawparallels(np.arange(-90, 90, 30))   #繪制緯線

lon = -74
lat = 40.43
x,y = map2(lon, lat)       #映射坐標
map2.plot(x, y, 'ro', markersize=8)  #繪制散點圖
plt.text(x,y,'New York')   #文本注釋

image
圖12.13 文本注釋

basemap綜合示例

本節將講解如何通過basemap繪制區域與全球地圖,結合具體案例,講解地圖的繪制方法和技巧,

美國人口分布

通過該網站(https://github.com/plotly/datasets/blob/master/2014_us_cities.csv)
下載2014年美國城市的人口資料,讀取資料,如圖12.14所示,資料總共有四個欄位,城市名稱、城市人口和經緯度坐標,
image

圖12.14 美國人口資料
通過以下代碼,繪制前180個城市的美國人口分布圖,如圖12.15所示,

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from mpl_toolkits.basemap import Basemap
%matplotlib inline

plt.style.use('ggplot')
plt.figure(figsize=(10,6))

map3 = Basemap(projection='stere', lat_0=90, lon_0=-105,
               llcrnrlon=-118.67, llcrnrlat=23.41,
               urcrnrlon=-64.5, urcrnrlat=45.44,
              resolution='l', area_thresh=1000.0) 
map3.drawcoastlines()  #繪制海岸線
map3.drawcountries()   #繪制國家
map3.drawmapboundary() #繪制邊界
map3.drawstates()      #繪制州
map3.drawcounties()      # 繪制縣

map3.drawmeridians(np.arange(0, 360, 30))    #繪制經線
map3.drawparallels(np.arange(-90, 90, 30))   #繪制緯線

lat = np.array(pop_data["lat"][0:180])                        # 獲取維度之維度值
lon = np.array(pop_data["lon"][0:180])                        # 獲取經度值
pop = np.array(pop_data["pop"][0:180],dtype=float)    # 獲取人口數,轉化為numpy浮點型
size = (pop/np.max(pop))*1000 # 計算每個點的大小

x,y = map3(lon,lat)
map3.scatter(x,y,s=size)

plt.title('Population distribution in America')     #加標題

代碼分析:
(1)1~5行
匯入程式需要的庫,
(2)7~8行
設定圖表的樣式為ggplot,并設定圖表的長寬比,
(3)10~21行
定義basemap物件,并繪制出美國的地圖底圖和經緯度,
(4)23~29
獲取前180個資料,并繪制散點圖,
image
圖12.15 美國人口分布圖
注意:人口如果不轉化為numpy浮點型,散點圖不會顯示出大小不一,

全球地震可視化

通過美國地震局官網(https://earthquake.usgs.gov/earthquakes/feed/v1.0/csv.php)
下載過去一周的地震資料,如圖12.16所示,
image
圖12.16 過去一周地震資料下載
讀取資料,如圖12.17所示,該資料有很多欄位,但本次分析中用到的就是經緯度欄位和mag欄位(震級),
image
圖12.17 地震資料
對這三個欄位查看缺失值,如圖12.18所示,mag欄位有1個缺失值,
image
圖12.18 查看缺失值
通過過濾剔除到這個缺失值,如圖12.19所示,
image
圖12.19 過濾缺失值
通過以下代碼,繪制地震分布圖,如圖12.20所示,

image
圖12.20 全球地震分布圖(1)
根據震級大小,繪制散點不一的地震分布圖,如圖12.21所示,

plt.style.use('ggplot')
plt.figure(figsize=(10,6))

map5 = Basemap(projection='robin', lat_0=39.9, lon_0=116.3,
               resolution = 'l', area_thresh = 1000.0) 

map5.drawcoastlines()
map5.drawcountries()
map5.drawmapboundary()

map5.drawmeridians(np.arange(0, 360, 30))
map5.drawparallels(np.arange(-90, 90, 30))

size = 2    #初始化大小
for lon, lat, mag in zip(list(eq_data['longitude']), list(eq_data['latitude']), list(eq_data['mag'])):
    x,y = map5(lon, lat)
    msize = mag * size     #不同震級大小不一樣
    map5.plot(x, y, 'ro', markersize=msize)

image
圖12.21 全球地震分布圖(2)
通過以下代碼,定義一個函式,可通過不同震級繪制顏色不同的地圖,如圖12.22所示,

def get_marker_color(mag):
    if mag < 3.0:
        return ('go')
    elif mag < 5.0:
        return ('yo')
    else:
        return ('ro')      #定義設定顏色函式

plt.style.use('ggplot')
plt.figure(figsize=(10,6))

map6 = Basemap(projection='robin', lat_0=39.9, lon_0=116.3,
               resolution = 'l', area_thresh = 1000.0) 

map6.drawcoastlines()
map6.drawcountries()
map6.drawmapboundary()

map6.drawmeridians(np.arange(0, 360, 30))
map6.drawparallels(np.arange(-90, 90, 30))

size = 2
for lon, lat, mag in zip(list(eq_data['longitude']), list(eq_data['latitude']), list(eq_data['mag'])):
    x,y = map6(lon, lat)
    msize = mag * size
    map6.plot(x, y, get_marker_color(mag), markersize=msize)   #呼叫函式

plt.title('Earthquakes')

image
圖12.22 全球地震分布圖(3)

pyecharts地圖繪制

pyecharts也可以輕松繪制出美觀可互動的地圖,本節將講解如何利用pyecharts繪制不同地區的地圖,通過Geo方法在地圖上繪制散點圖,

地圖

利用pyecharts繪制地圖,需要下載地圖js檔案,通過pip進行安裝,如圖12.23所示,

pip install echarts-countries-pypkg        #全球國家地圖
pip install echarts-china-provinces-pypkg  #中國省級地圖
pip install echarts-china-cities-pypkg      #中國市級地圖

image
圖12.23 安裝地圖js
注意:安裝好后記得重啟jupyter notebook,
利用Map方法可繪制地圖,代碼如下,

value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[155, 78, 23, 65]
label = ["北京", "上海", "西藏", "廣東"]
map1 = pyecharts.Map("全國地圖示例")
map1.add("",label, value, maptype='china')
map1.render()   #生成html檔案
該add方法的引數如下,maptype設定地圖型別,支持china、world、中國省市名稱等;is_roam可縮放地圖;is_map_symbol_show顯示地圖紅點,
add(name, attr, value,
    maptype='china',
    is_roam=True,
    is_map_symbol_show=True, **kwargs)

繪制的中國地圖如圖12.24所示,
image
圖12.24 全國地圖(1)
設定is_label_show=True,可以顯示各省份名稱,代碼如下,如圖12.25所示,

value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[155, 78, 23, 65]
label = ["北京", "上海", "西藏", "廣東"]
map1 = pyecharts.Map("全國地圖示例", width=1200, height=600)
map1.add("",label, value, maptype='china', is_label_show=True)
map1.render()   #生成html檔案

image
圖12.25 全國地圖(2)
結合Visualmap可以美化地圖,根據值顯示不同顏色,代碼如下,如圖12.26所示,

value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[155, 78, 23, 65]
label = ["北京", "上海", "西藏", "廣東"]
map1 = pyecharts.Map("全國地圖示例", width=1200, height=600)
map1.add("",label, value, maptype='china', is_visualmap=True,
        visual_text_color='#000')
map1.render()   #生成html檔案

image
圖12.26 全國地圖(3)
修改maptype引數可以繪制省級地圖,代碼如下,如圖12.27所示,

value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[233, 102, 41, 82]
attr = ['武漢市', '咸寧市', '黃岡市', '黃石市']
map1 = pyecharts.Map("湖北省地圖")
map1.add("", attr, value, maptype='湖北', is_visualmap=True,
        visual_text_color='#000')
map1.render()

image
圖12.27 湖北省地圖
修改maptype引數為world可以繪制世界地圖,代碼如下,如圖12.28所示,

value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[46, 54, 45, 82, 45]
attr= ["China", "Canada", "Brazil", "Russia", "United States"]
map1 = pyecharts.Map("世界地圖", width=1200, height=600)
map1.add("", attr, value, maptype="world", is_visualmap=True,
        visual_text_color='#000', is_map_symbol_show=False)
map1.render()

image
圖12.28 全球地圖

地圖坐標系

地圖坐標系組件用于地圖的繪制,支持在地圖上繪制散點圖,線集,利用Geo方法可在地圖上繪制散點圖等,代碼如下,

data = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[
    ('上海', 78),('武漢', 56),('長沙', 45),('北京', 65),('蘇州', 32),('鹽城', 15),
    ('南昌', 87),('青島', 45),('廣州', 78),('拉薩', 12),('桂林', 21),('西安', 42),
    ('濟南', 12)]

geo = pyecharts.Geo("地圖繪制案例一",
          title_pos="center", width=1200,
          height=600)
attr, value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/geo.cast(data)
geo.add("", attr, value, visual_range=[0, 100], visual_text_color="#fff",
        geo_normal_color="#FFFFFF",
        symbol_size=15, is_visualmap=True)
geo.render()

該add方法的引數如下,type設定圖例型別,'scatter', 'effectScatter', 'heatmap'可選;
symbol_size為散點圖大小;
border_color設定地圖邊界顏色;
geo_normal_color為正常情況下地圖區域顏色;
geo_emphasis_color為高亮下地圖區域的顏色,

add(name, attr, value,
    type="scatter",
    maptype='china',
    symbol_size=12,
    border_color="#111",
    geo_normal_color="#323c48",
    geo_emphasis_color="#2a333d",
    is_roam=True, **kwargs)

繪制的地圖如圖12.29所示,
image
圖12.29 案例一
修改type引數,更改為heatmap,代碼如下,如圖12.30所示,

data = https://www.cnblogs.com/cheng020406/archive/2023/06/06/[
    ('上海', 78),('武漢', 56),('長沙', 45),('北京', 65),('蘇州', 32),('鹽城', 15),
    ('南昌', 87),('青島', 45),('廣州', 78),('拉薩', 12),('桂林', 21),('西安', 42),
    ('濟南', 12)]

geo = pyecharts.Geo("地圖繪制案例二",
          title_pos="center", width=1200,
          height=600)
attr, value = https://www.cnblogs.com/cheng020406/archive/2023/06/06/geo.cast(data)
geo.add("", attr, value, type='heatmap', visual_range=[0, 100], visual_text_color="#fff",
        geo_normal_color="#FFFFFF",
        symbol_size=15, is_visualmap=True)
geo.render()

image
圖12.30 案例二

本文來自博客園,作者:原力星球,轉載請注明原文鏈接:https://www.cnblogs.com/cheng020406/p/17461722.html

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/554481.html

標籤:其他

上一篇:演算法 in Golang:Recursion(遞回)

下一篇:返回列表

標籤雲
其他(160482) Python(38206) JavaScript(25478) Java(18205) C(15237) 區塊鏈(8270) C#(7972) AI(7469) 爪哇(7425) MySQL(7234) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4585) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1983) 功能(1967) HtmlCss(1952) Web開發(1951) C++(1932) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1879) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • 8-地圖可視化與seaborn可視化

    # 地圖可視化 basemap安裝和使用 區域縮放與繪圖 綜合案例:美國人口分布圖 # seaborn可視化 樣式與分布圖 分類圖 # basemap地圖繪制 地圖繪制也是資料可視化的一部分,常用的地圖繪制庫為basemap工具包,其為matplotlib的子包。本章將講解如何利用whl檔案在Pyt ......

    uj5u.com 2023-06-07 07:40:38 more
  • 演算法 in Golang:Recursion(遞回)

    # 演算法 in Golang:Recursion(遞回) ## 遞回演算法 ### 場景:在套娃中找到寶石 ### 可以這樣做 - while 沒找到: - if 當前項 is 寶石: - return 寶石 - else if 當前項 is 套娃: - 打開這個套娃 - if 當前項 is 寶石: ......

    uj5u.com 2023-06-07 07:39:52 more
  • JVM運行時資料區

    # JVM運行時資料區 ## 簡介 JVM運行時資料區包括:JVM堆疊(虛擬機堆疊),堆,方法區,本地方法堆疊,PC暫存器。大概的劃分就是堆疊和堆,以及一些其他的結構。重點在JVM堆疊,堆,方法區。JVM規范指出:方法區在邏輯上屬于堆,但是實際的具體的JVM中并不屬于堆的一部分。 在JVM堆疊中會發生GC和Er ......

    uj5u.com 2023-06-07 07:39:32 more
  • 20個Golang片段讓我不再健忘

    本文使用代碼片段的形式來解釋在 go 語言開發中經常遇到的小功能點,由于本人主要使用 java 開發,因此會與其作比較,希望對大家有所幫助。 ......

    uj5u.com 2023-06-07 07:39:21 more
  • Python 中 yeild 的用法

    本文包含以下四部分: > 1. yeild 介紹 > 2. yeild 案例 > 3. 簡單的例子對比yeild和常規函式 > 4. 復雜的例子說明yeild 與普通函式的差異 ### 1. yeild 介紹 yield 是 Python 的一個關鍵字,用于從一個函式中回傳一個生成器(generat ......

    uj5u.com 2023-06-07 07:39:16 more
  • 47基于java的養老院管理系統設計與實作

    基于java的養老院管理系統設計與實作;可適用于敬老院管理系統,老人管理系統,老人資訊管理系統,java養老院資訊系統,java敬老院資訊管理系統; ......

    uj5u.com 2023-06-07 07:39:12 more
  • java集成OpenAI的chatGpt功能

    一、開通OpenAI賬號 1.注冊OpenAI賬號 官網地址:https://openai.com/ 注意:提前準備好國外手機號,沒有的話用短信平臺購買手機號接收短信 2.購買國外手機號 地址:https://tiger-sms.com/ 我用支付寶充值了30多元(起充要30,加上手續費30多有點坑 ......

    uj5u.com 2023-06-07 07:33:27 more
  • Java革命性ORM框架之快速上手的Jimmer

    Jimmer是一款革命性的ORM框架,它的目標是提供一個簡單易用的API,幫助開發人員更加輕松地操作資料庫。Jimmer使用了Java 8的新特性,如Lambda運算式和Stream API,使得代碼更加簡潔、易讀。本文將詳細介紹Jimmer的基本用法,并提供一些Java代碼案例說明。 # 1. 什 ......

    uj5u.com 2023-06-06 15:25:39 more
  • ubuntu 搭建 cmake + vscode 的 c/c++ 開發環境

    # 軟體安裝 略 # 最基本的 vscode 插件 只需要安裝如下兩個插件即可 c/c++ 擴展是為了最基本的代碼提示和除錯支持 cmake language support 是為了提示 CMakeLists.txt 腳本 ![image](https://img2023.cnblogs.com/b ......

    uj5u.com 2023-06-06 15:09:20 more
  • 45基于java的民宿管理平臺設計與實作

    基于java的民宿管理平臺設計與實作,java民宿,民宿預約管理平臺系統,酒店預訂系統,酒店管理系統,酒店房間預訂,旅游業有關網上民宿預訂酒店房間管理系統,民宿資訊管理平臺。 ......

    uj5u.com 2023-06-06 15:02:13 more