主頁 > 後端開發 > 不知道天氣咋樣?一起用Python爬取天氣資料分析告訴你

不知道天氣咋樣?一起用Python爬取天氣資料分析告訴你

2021-07-31 08:19:19 後端開發

前言

今天我們分享一個小案例,獲取天氣資料,進行可視化分析,帶你直觀了解天氣情況!

一、核心功能設計

總體來說,我們需要先對中國天氣網中的天氣資料進行爬取,保存為csv檔案,并將這些資料進行可視化分析展示,

拆解需求,大致可以整理出我們需要分為以下幾步完成:

  1. 通過爬蟲獲取中國天氣網7.20-7.21的降雨資料,包括城市,風力方向,風級,降水量,相對濕度,空氣質量
  2. 對獲取的天氣資料進行預處理,分析河南的風力等級和風向,繪制風向風級雷達圖
  3. 根據獲取的溫度和濕度繪制溫濕度相關性分析圖,進行溫度、濕度對比分析,
  4. 根據獲取的各城市的降雨量,可視化近24小時的每小時時段降水情況
  5. 繪制各城市24小時的累計降雨量

二、實作步驟

1. 爬取資料

首先我們需要獲取各個城市的降雨資料,通過對中國天氣網網址分析發現,城市的天氣網址為:http://www.weather.com.cn/weather/101180101.shtml,

在這里插入圖片描述

根據對資料分析,回傳的json格式資料,不難發現:

  • 101180101就是代表城市編號
  • 7天的天氣預報資料資訊在div標簽中并且id=“7d”
  • 日期、天氣、溫度、風級等資訊都在ul和li標簽

網頁結構我們上面已經分析好了,那么我們就可以來動手爬取所需要的資料了,獲取到所有的資料資源之后,可以把這些資料保存下來,

請求網站:

天氣網的網址:http://www.weather.com.cn/weather/101180101.shtml,如果想爬取不同的地區只需修改最后的101180101地區編號,前面的weather代表是7天的網頁,

def getHTMLtext(url):
	"""請求獲得網頁內容"""
	try:
		r = requests.get(url, timeout = 30)
		r.raise_for_status()
		r.encoding = r.apparent_encoding
		print("Success")
		return r.text
	except:
		print("Fail")
		return" "

在這里插入圖片描述

處理資料:

采用BeautifulSoup庫對剛付訓取的字串進行資料提取,獲取我們需要的風力方向,風級,降水量,相對濕度,空氣質量等,

def get_content(html,cityname):
	"""處理得到有用資訊保存資料檔案"""
	final = []  							 # 初始化一個串列保存資料
	bs = BeautifulSoup(html, "html.parser")  # 創建BeautifulSoup物件
	body = bs.body
	data = body.find('div', {'id': '7d'})    # 找到div標簽且id = 7d
	# 下面爬取當天的資料
	data2 = body.find_all('div',{'class':'left-div'})
	text = data2[2].find('script').string
	text = text[text.index('=')+1 :-2]		 # 移除改var data=將其變為json資料
	jd = json.loads(text)
	dayone = jd['od']['od2']				 # 找到當天的資料
	final_day = []						     # 存放當天的資料
	count = 0
	for i in dayone:
		temp = []
		if count <=23:
			temp.append(i['od21'])				 # 添加時間
			temp.append(cityname+'市')			# 添加城市
			temp.append(i['od22'])				 # 添加當前時刻溫度
			temp.append(i['od24'])				 # 添加當前時刻風力方向
			temp.append(i['od25'])				 # 添加當前時刻風級
			temp.append(i['od26'])				 # 添加當前時刻降水量
			temp.append(i['od27'])				 # 添加當前時刻相對濕度
			temp.append(i['od28'])				 # 添加當前時刻控制質量
# 			print(temp)
			final_day.append(temp)
			data_all.append(temp)
		count = count +1
	# 下面爬取24h的資料
	ul = data.find('ul')                     # 找到所有的ul標簽
	li = ul.find_all('li')                   # 找到左右的li標簽
	i = 0                                    # 控制爬取的天數
	for day in li:                          # 遍歷找到的每一個li
	    if i < 7 and i > 0:
	        temp = []                        # 臨時存放每天的資料
	        date = day.find('h1').string     # 得到日期
	        date = date[0:date.index('日')]  # 取出日期號
	        temp.append(date)
	        inf = day.find_all('p')          # 找出li下面的p標簽,提取第一個p標簽的值,即天氣
	        temp.append(inf[0].string)

	        tem_low = inf[1].find('i').string  	# 找到最低氣溫

	        if inf[1].find('span') is None:  	# 天氣預報可能沒有最高氣溫
	            tem_high = None
	        else:
	            tem_high = inf[1].find('span').string  # 找到最高氣溫
	        temp.append(tem_low[:-1])
	        if tem_high[-1] == '℃':
	        	temp.append(tem_high[:-1])
	        else:
	        	temp.append(tem_high)

	        wind = inf[2].find_all('span')		# 找到風向
	        for j in wind:
	        	temp.append(j['title'])

	        wind_scale = inf[2].find('i').string # 找到風級
	        index1 = wind_scale.index('級')
	       	temp.append(int(wind_scale[index1-1:index1]))
	        final.append(temp)
	    i = i + 1
	return final_day,final

城市的天氣資料拿到了,同理我們可以根據不同的地區編號獲取河南省各個地級市的天氣資料,

Citycode = { "鄭州": "101180101",
             "新鄉": "101180301",
             "許昌": "101180401",
             "平頂山": "101180501",
             "信陽": "101180601",
             "南陽": "101180701",
             "開封": "101180801",
             "洛陽": "101180901",
             "商丘": "101181001",
             "焦作": "101181101",
             "鶴壁": "101181201",
             "濮陽": "101181301",
             "周口": "101181401",
             "漯河": "101181501",
             "駐馬店": "101181601",
             "三門峽": "101181701",
             "濟源": "101181801",
             "安陽": "101180201"}
citycode_lists = list(Citycode.items())
for city_code in citycode_lists:
    city_code = list(city_code)
    print(city_code)
    citycode = city_code[1]
    cityname = city_code[0]
    url1 = 'http://www.weather.com.cn/weather/'+citycode+ '.shtml'    # 24h天氣中國天氣網
	html1 = getHTMLtext(url1)
	data1, data1_7 = get_content(html1,cityname)		# 獲得1-7天和當天的資料

存盤資料:

def write_to_csv(file_name, data, day=14):
	"""保存為csv檔案"""
	with open(file_name, 'a', errors='ignore', newline='') as f:
		if day == 14:
			header = ['日期','城市','天氣','最低氣溫','最高氣溫','風向1','風向2','風級']
		else:
			header = ['小時','城市','溫度','風力方向','風級','降水量','相對濕度','空氣質量']
		f_csv = csv.writer(f)
		f_csv.writerow(header)
		f_csv.writerows(data)
write_to_csv('河南天氣.csv',data_all,1)

這樣我們就可以把全省的各個地級市天氣資料保存下來了,

在這里插入圖片描述

2. 風向風級雷達圖

統計全省的風力和風向,因為風力風向使用極坐標的方式展現比較清晰,所以我們采用極坐標的方式展現一天的風力風向圖,將圓分為8份,每一份代表一個風向,半徑代表平均風力,并且隨著風級增高,藍色加深,

def wind_radar(data):
	"""風向雷達圖"""
	wind = list(data['風力方向'])
	wind_speed = list(data['風級'])
	for i in range(0,24):
		if wind[i] == "北風":
			wind[i] = 90
		elif wind[i] == "南風":
			wind[i] = 270
		elif wind[i] == "西風":
			wind[i] = 180
		elif wind[i] == "東風":
			wind[i] = 360
		elif wind[i] == "東北風":
			wind[i] = 45
		elif wind[i] == "西北風":
			wind[i] = 135
		elif wind[i] == "西南風":
			wind[i] = 225
		elif wind[i] == "東南風":
			wind[i] = 315
	degs = np.arange(45,361,45)
	temp = []
	for deg in degs:
		speed = []
		# 獲取 wind_deg 在指定范圍的風速平均值資料
		for i in range(0,24):
			if wind[i] == deg:
				speed.append(wind_speed[i])
		if len(speed) == 0:
			temp.append(0)
		else:
			temp.append(sum(speed)/len(speed))
	print(temp)
	N = 8
	theta = np.arange(0.+np.pi/8,2*np.pi+np.pi/8,2*np.pi/8)
	# 資料極徑
	radii = np.array(temp)
	# 繪制極區圖坐標系
	plt.axes(polar=True)
	# 定義每個扇區的RGB值(R,G,B),x越大,對應的顏色越接近藍色
	colors = [(1-x/max(temp), 1-x/max(temp),0.6) for x in radii]
	plt.bar(theta,radii,width=(2*np.pi/N),bottom=0.0,color=colors)
	plt.title('河南風級圖--Dragon少年',x=0.2,fontsize=16)
	plt.show()

結果如下:
在這里插入圖片描述

觀察可以發現,當天的東北風最多,平均風級達到了1.75級,

3. 溫濕度相關性分析

我們可以分析溫度和濕度之間是否存在關系,為了更加清楚直觀地驗證,可以使用離散點plt.scatter()方法將溫度為橫坐標、濕度為縱坐標,每個時刻的點在圖中點出來,并且計算相關系數,

def calc_corr(a, b):
	"""計算相關系數"""
	a_avg = sum(a)/len(a)
	b_avg = sum(b)/len(b)
	cov_ab = sum([(x - a_avg)*(y - b_avg) for x,y in zip(a, b)])
	sq = math.sqrt(sum([(x - a_avg)**2 for x in a])*sum([(x - b_avg)**2 for x in b]))
	corr_factor = cov_ab/sq
	return corr_factor


def corr_tem_hum(data):
	"""溫濕度相關性分析"""
	tem = data['溫度']
	hum = data['相對濕度']
	plt.scatter(tem,hum,color='blue')
	plt.title("溫濕度相關性分析圖--Dragon少年")
	plt.xlabel("溫度/℃")
	plt.ylabel("相對濕度/%")
	# plt.text(20,40,"相關系數為:"+str(calc_corr(tem,hum)),fontdict={'size':'10','color':'red'})
	plt.show()
	print("相關系數為:"+str(calc_corr(tem,hum)))

結果如下:

在這里插入圖片描述
觀察可以發現,一天的溫度和濕度具有強烈的相關性,呈負相關,當溫度較低時,空氣中水分含量較多,濕度自然較高,而溫度較高時,水分蒸發,空氣就比較干燥,濕度較低,

4. 24小時內每小時時段降水

from pyecharts import options as opts
from pyecharts.charts import Map,Timeline
#定義一個timeline和map的組合圖
def timeline_map(data):
    tl = Timeline().add_schema(play_interval =300,height=40,is_rewind_play=False,orient = "horizontal",is_loop_play = True,is_auto_play=False)#設定播放速度、是否回圈播放等引數
    for h in time_line_final:
        x =data[data["小時"]==h]['城市'].values.tolist() #選取指定城市
        y=data[data["小時"]==h]['降水量'].values.tolist() #選取時間的降水量
        map_shape = (
            Map()
            .add("{}h時降水量(mm)".format(h),[list(z) for z in zip(x, y)],"河南") #打包輸入地區及對應降水量資料
            .set_series_opts(label_opts=opts.LabelOpts("{b}")) #配置系列引數,{b}為顯示地區資料
            .set_global_opts(
                title_opts=opts.TitleOpts(title="河南省降雨分布--Dragon少年"), #全域引數中設定標題
                visualmap_opts=opts.VisualMapOpts(max_=300,  #設定映射配置項的最大值
                                                  is_piecewise=True, #設定是否為分段顯示
                                                  pos_top = "60%", #映射配置項距圖片上部的距離
                                                  pieces=[
                                                        {"min": 101, "label": '>100ml', "color": "#FF0000"},  # 分段指定顏色及名稱
                                                        {"min": 11, "max": 50, "label": '11-50ml', "color": "#FF3333"},
                                                        {"min": 6, "max": 10, "label": '6-10ml', "color": "#FF9999"},
                                                        {"min": 0.1, "max": 5, "label": '0.1-5ml', "color": "#FFCCCC"}])
        ))
        tl.add(map_shape, "{}h".format(h)) #將不同日期的資料加入到timeline中
    return tl
timeline_map(data).render("rainfall.html")

效果如下:

在這里插入圖片描述

觀察可以發現,7.20當天大部分地區均有雨,7月20日17時-18時一小時的降水量達到了201.9mm,

4. 24小時累計降雨量

from pyecharts import options as opts
from pyecharts.charts import Map,Timeline
#定義一個timeline和map的組合圖
time_line_final = list(data1['小時'].iloc[0:24])
def timeline_map(data1):
    tl = Timeline().add_schema(play_interval =200,height=40,is_rewind_play=False,orient = "horizontal",is_loop_play = True,is_auto_play=True)#設定播放速度、是否回圈播放等引數
    for h in time_line_final:
        x =data1[data1["小時"]==h]['城市'].values.tolist() #選取指定城市
        y=data1[data1["小時"]==h]['降水量'].values.tolist() #選取時間的降水量
        map_shape1 = (
            Map()
            .add("{}h時累計降水量(mm)".format(h),[list(z) for z in zip(x, y)],"河南") #打包輸入地區及對應降水量資料
            .set_series_opts(label_opts=opts.LabelOpts("{b}")) #配置系列引數,{b}為顯示地區資料
            .set_global_opts(
                title_opts=opts.TitleOpts(title="河南省累計降雨分布--Dragon少年"), #全域引數中設定標題
                visualmap_opts=opts.VisualMapOpts(max_=300,  #設定映射配置項的最大值
                                                  is_piecewise=True, #設定是否為分段顯示
                                                  pos_top = "60%", #映射配置項距圖片上部的距離
                                                  pieces=[
                                                        {"min": 251, "label": '特大暴雨', "color": "#800000"},  # 分段指定顏色及名稱
                                                        {"min": 101, "max": 250, "label": '暴雨', "color": "#FF4500"},
                                                        {"min": 51, "max": 100, "label": '暴雨', "color": "#FF7F50"},
                                                        {"min": 25, "max": 50, "label": '大雨', "color": "#FFFF00"},
                                                        {"min": 10, "max": 25, "label": '中雨', "color": "#1E90FF"},
                                                        {"min": 0.1, "max": 9.9, "label": '小雨', "color": "#87CEFA"}])
        ))
        tl.add(map_shape1, "{}h".format(h)) #將不同日期的資料加入到timeline中
    return tl
timeline_map(data1).render("rainfalltoall_1.html")

效果如下:

在這里插入圖片描述

至此,天氣資料分析可視化就完成啦~

今天我們就到這里,明天繼續努力!
在這里插入圖片描述
若本篇內容對您有所幫助,請三連點贊,關注,收藏支持下,

創作不易,白嫖不好,各位的支持和認可,就是我創作的最大動力,我們下篇文章見!

Dragon少年 | 文

如果本篇博客有任何錯誤,請批評指教,不勝感激 !

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

標籤:python

上一篇:?「和平精英」被python爬蟲了?看看你最適合什么配件!?

下一篇:Python知識點(史上最全)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(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
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more