python數據分析知識點_Python數據分析--Pandas知識點(三)

本文主要是總結學習pandas過程中用到的函數和方法, 在此記錄, 防止遺忘.

下面將是在知識點一, 二的基礎上繼續總結.

前面所介紹的都是以表格的形式中展現數據, 下面將介紹Pandas與Matplotlib配合繪制出折線圖, 散點圖, 餅圖, 柱形圖, 直方圖等五大基本圖形.

Matplotlib是python中的一個2D圖形庫, 它能以各種硬拷貝的格式和跨平臺的交互式環境生成高質量的圖形, 比如說柱狀圖, 功率譜, 條形圖, 誤差圖, 散點圖等. 其中, matplotlib.pyplot 提供了一個類似matlab的繪圖框架, 使用該框架前, 必須先導入它.

19. 折線圖

折線圖: 數據隨著時間的變化情況描點連線而形成的圖形, 通常被用于顯示在相等時間間隔下數據的趨勢. 下面將采用兩種方式進行繪制折線圖, 一種是pandas中plot()方法, 該方法用來繪制圖形, 然后在matplotlib中的繪圖框架中展示; 另一種則是直接利用matplotlib中繪圖框架的plot()方法.

19.1 采用pandas中的plot()方法繪制折線圖

在pandas中繪制折線圖的函數是plot(x=None, y=None, kind='line', figsize = None, legend=True,style=None, color = "b", alpha = None):

第一個: x軸的數據

第二個: y軸的數據

第三個: kind表示圖形種類, 默認為折線圖

第四個: figsize表示圖像大小的元組

第五個: legend=True表示使用圖例, 否則不使用, 默認為True.

第六個: style表示線條樣式

第七個: color表示線條顏色, 默認為藍色

第八個: alpha表示透明度, 介于0~1之間.

1 importpandas as pd2 importmatplotlib.pyplot as plt3 #第一步讀取數據: 使用read_csv()函數讀取csv文件中的數據

4 df = pd.read_csv(r"D:\Data\percent-bachelors-degrees-women-usa.csv")5 #第二步利用pandas的plot方法繪制折線圖

6 df.plot(x = "Year", y = "Agriculture")7 #第三步: 通過plt的show()方法展示所繪制圖形

8 plt.show()

在執行上述代碼過程了報錯ImportError: matplotlib is required for plotting, 若遇到請點擊參考辦法

最終顯示效果:

1469712-20180929191212412-228318510.png

如果想將實線變為虛線呢, 可修改style參數為"--":

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\percent-bachelors-degrees-women-usa.csv")4 #添加指定的style參數

5 df.plot(x = "Year", y = "Agriculture", style = "--")6 plt.show()

1469712-20180929192514537-284791288.png

添加坐標軸標簽以及標題:

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\percent-bachelors-degrees-women-usa.csv")4 df.plot(x = "Year", y = "Agriculture", style = "--")5 #添加橫坐標軸標簽

6 plt.xlabel("Year")7 #添加縱坐標軸標簽

8 plt.ylabel("Percent")9 #添加標題

10 plt.title("Percent of American women earn Agriculture's degree")11 plt.show()

1469712-20180929193206020-1334775110.png

19.2 采用matplotlib.pyplot的plot()方法繪制折線圖

matplotlib.pyplot.plot(x, y, style, color, linewidth)函數的參數分別表示: x軸數據, y軸數據, style線條樣式, color線條顏色, linewidth線寬.

1 importpandas as pd2 importmatplotlib.pyplot as plt3 #第一步: 讀取數據

4 df = pd.read_csv(r"D:\Data\percent-bachelors-degrees-women-usa.csv")5 #第二步: 將所需數據賦值給對應的變量

6 df_year, df_Agriculture = df["Year"], df["Agriculture"]7 #第三步: 用matplotlib中繪圖框架的plot()方法繪制紅色的折線圖

8 plt.plot(df_year, df_Agriculture,"-", color = "r",linewidth = 10)9 #添加橫坐標軸標簽

10 plt.xlabel("Year")11 #添加縱坐標軸標簽

12 plt.ylabel("Percent")13 #添加標題

14 plt.title("Percent of American women earn Agriculture's degree")15 plt.show()

顯示效果:

1469712-20180929214029894-16838686.png

20. 散點圖

散點圖: 用兩組數據構成多個坐標點, 考察坐標點的分布, 判斷兩變量之間是否存在某種關聯或總結坐標點的分布模式. 各點的值由點在坐標中的位置表示, 用不同的標記方式表示各點所代表的不同類別.

20.1 采用pandas中的plot()方法繪制散點圖

只需將plot()函數中的kind參數的值改為"scatter"即可.

1 importpandas as pd2 importmatplotlib.pyplot as plt3 #讀取數據

4 df = pd.read_csv(r"D:\Data\Iris.csv")5 #原始數據中沒有給出字段名, 在這里指定

6 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']7 #指定x軸與y軸數據并繪制散點圖

8 df.plot(x = "sepal_len", y = "sepal_wid", kind = "scatter")9 #添加橫坐標軸標簽

10 plt.xlabel("sepal length")11 #添加縱坐標軸標簽

12 plt.ylabel("sepal width")13 #添加標題

14 plt.title("Iris sepal length and width analysis")15 plt.show()

1469712-20180929220748576-461060494.png

20.2 采用matplotlib.pyplot的plot()方法繪制散點圖

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\Iris.csv")4 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']5 #用繪圖框架的plot()方法繪圖, 樣式為".", 顏色為紅色

6 plt.plot(df["sepal_len"], df["sepal_wid"],".", color = "r")7 plt.xlabel("sepal length")8 plt.ylabel("sepal width")9 plt.title("Iris sepal length and width analysis")10 plt.show()

1469712-20180929221807997-1049156346.png

21. 餅圖

餅圖: 將一個圓形劃分為多個扇形的統計圖, 它通常被用來顯示各個組成部分所占比例.

由于在繪制餅狀圖先要對數據進行分類匯總, 先查看數據的總體信息

1 importpandas as pd2 df = pd.read_csv(r"D:\Data\Iris.csv")3 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']4 #查看數據總體信息

5 df.describe()

1469712-20180929230401782-918687886.png

可以看出每一列都是149個數據, 那么接下來對species列進行分類匯總

1 importpandas as pd2 df = pd.read_csv(r"D:\Data\Iris.csv")3 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']4 #對species列進行分類并對sepal_len列進行計數

5 df_gbsp = df.groupby("species")["sepal_len"].agg(["count"])6 df_gbsp

1469712-20180930001946615-552894515.png

21.1 采用pandas中的plot()方法繪制餅狀圖

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\Iris.csv")4 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']5 #對species列進行分類并對sepal_len列進行計數

6 df_gbsp = df.groupby("species")["sepal_len"].agg(["count"])7 #繪制圖形樣式為餅圖, 百分比保留兩位小數, 字體大小為20, 圖片大小為6x6, subplots為True表示將數據每列繪制為一個子圖,legend為True表示隱藏圖例

8 df_gbsp.plot(kind = "pie", autopct='%.2f%%', fontsize=20, figsize=(6, 6), subplots = True, legend =False)9 plt.show()

1469712-20180930010320980-933962627.png

21.2 采用matplotlib.pyplot的pie()方法繪制餅狀圖

pie(x, explode = None, labels = None, colors=None, autopct=None)的參數分別表示:

第一個: x表示要繪圖的序列

第二個: explode要突出顯示的組成部分

第三個: labels各組成部分的標簽

第四個: colors各組成部分的顏色

第五個: autopct數值顯示格式

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\Iris.csv")4 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']5 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))6 df_gbsp = df.groupby("species",as_index = False)["sepal_len"].agg({"counts": "count"})7 #對counts列的數據繪制餅狀圖.

8 plt.pie(df_gbsp["counts"],labels = df_gbsp["species"], autopct = "%.2f%%")9 plt.show()

1469712-20180930025723579-59666819.png

22. 柱形圖

柱形圖: 又稱為長條圖, 是一種以長方形的長度為變量的統計圖. 柱形圖常用來比較兩個或以上的數據不同時間或者不同條件).

22.1 采用pandas的plot()方法繪制柱形圖

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\Iris.csv")4 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']5 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))6 #對species分組求均值

7 df_gbsp = df.groupby("species", as_index =False).mean()8 #繪制柱形圖

9 df_gbsp.plot(kind = "bar")10 #修改橫坐標軸刻度值

11 plt.xticks(df_gbsp.index,df_gbsp["species"],rotation=360)12 plt.show()

1469712-20180930193304567-321576279.png

當然也可以繪制橫向柱形圖

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\Iris.csv")4 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']5 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))6 df_gbsp = df.groupby("species", as_index =False).mean()7 #將bar改為barh即可繪制橫向柱形圖

8 df_gbsp.plot(kind = "barh")9 plt.yticks(df_gbsp.index,df_gbsp["species"],rotation=360)10 plt.show()

1469712-20180930193600362-604419749.png

若想要將樣式改為堆積柱形圖:

#修改stacked參數為True即可

df_gbsp.plot(kind = "barh", stacked = True)

1469712-20180930195128707-138191399.png

22.2 采用matplotlib.pyplot的bar()方法繪制柱形圖

bar( x, height, width=0.8, color = None, label =None, bottom =None, tick_label = None)的參數分別表示:

第一個: x表示x軸的位置序列

第二個: height表示某個系列柱形圖的高度

第三個: width表示某個系列柱形圖的寬度

第四個: label表示圖例

第五個: bottom表示底部為哪個系列, 常被用在堆積柱形圖中

第六個: tick_label刻度標簽

1 importpandas as pd2 importmatplotlib.pyplot as plt3 df = pd.read_csv(r"D:\Data\Iris.csv")4 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']5 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))6 df_gbsp = df.groupby("species").mean()7 #繪制"sepal_len"列柱形圖

8 plt.bar(df_gbsp.index,df_gbsp["sepal_len"], width= 0.5 , color = "g")9 plt.show()

1469712-20180930213651046-264875366.png

繪制多組柱形圖:

1 importnumpy as np2 importpandas as pd3 importmatplotlib.pyplot as plt4 df = pd.read_csv(r"D:\Data\Iris.csv")5 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']6 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))7 df_gbsp = df.groupby("species").mean()8 #計算有多少個列

9 len_spe =len(df_gbsp.count())10 #計算有多少行, 并生成一個步進為1的數組

11 index =np.arange(len(df_gbsp.index))12 #設置每組總寬度

13 total_width= 1.4

14 #求出每組每列寬度

15 width = total_width/len_spe16 #對每個字段進行遍歷

17 for i inrange(len_spe):18 #得出每個字段的名稱

19 het =df_gbsp.columns[i]20 #求出每個字段所包含的數組, 也就是對應的高度

21 y_values =df_gbsp[het]22 #設置x軸標簽

23 x_tables = index * 1.5 + i*width24 #繪制柱形圖

25 plt.bar(x_tables, y_values, width =width)26 #通過zip接收(x_tables,y_values),返回一個可迭代對象, 每一個元素都是由(x_tables,y_values)組成的元組.

27 for x, y inzip(x_tables, y_values):28 #通過text()方法設置數據標簽, 位于柱形中心, 最頂部, 字體大小為10.5

29 plt.text(x, y ,'%.2f'% y ,ha='center', va='bottom', fontsize=10.5)30 #設置x軸刻度標簽位置

31 index1 = index * 1.5 + 1/2

32 #通過xticks設置x軸標簽為df_gbsp的索引

33 plt.xticks(index1 , df_gbsp.index)34 #添加圖例

35 plt.legend(df_gbsp.columns)36 plt.show()

1469712-20181001172104799-805508697.png

繪制堆積柱形圖

1 importnumpy as np2 importpandas as pd3 importmatplotlib.pyplot as plt4 df = pd.read_csv(r"D:\Data\Iris.csv")5 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']6 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))7 df_gbsp = df.groupby("species").mean()8 len_spe =len(df_gbsp.count())9 index =np.arange(len(df_gbsp.index))10 total_width= 1

11 width = total_width/len_spe12 ysum =013 for i inrange(len_spe):14 het =df_gbsp.columns[i]15 y_values =df_gbsp[het]16 #將x軸標簽改為index/2, 之后在設置bottom為ysum.

17 plt.bar(index/2, y_values, width =width, bottom =ysum)18 ysum, ysum1= ysum+y_values, ysum19 #計算堆積后每個區域中心對應的高度

20 zsum = ysum1 + (ysum - ysum1)/2

21 for x, y , z in zip(index/2, y_values, zsum):22 plt.text(x, z ,'%.2f'% y ,ha='center', va='center', fontsize=10.5)23 plt.xticks(index/2, df_gbsp.index)24 plt.legend(df_gbsp.columns)25 plt.show()

1469712-20181001204110749-1580788563.png

bar()函數是用來繪制豎直柱形圖, 而繪制橫向柱形圖用barh()函數即可, 兩者用法相差不多

23. 直方圖

直方圖: 由一系列高度不等的長方形表示數據分布的情況, 寬度表示間隔, 高度表示在對應寬度下出現的頻數.

23.1 采用pandas中的plot()方法繪制折線圖

1 importnumpy as np2 importpandas as pd3 importmatplotlib.pyplot as plt4 df = pd.read_csv(r"D:\Data\Iris.csv")5 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']6 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))7 df_gbsp = df["sepal_len"]8 #繪制直方圖

9 df_gbsp.plot(kind = "hist")10 plt.show()

1469712-20181001213433713-453825005.png

#可修改cumulative=True實現累加直方圖, 以及通過bins參數修改分組數

df_gbsp.plot(kind = "hist", cumulative='True', bins = 20)

1469712-20181001214141646-609698699.png

23.2 采用matplotlib.pyplot的hist()方法繪制折線圖

1 importnumpy as np2 importpandas as pd3 importmatplotlib.pyplot as plt4 df = pd.read_csv(r"D:\Data\Iris.csv")5 df.columns = ['sepal_len', 'sepal_wid', 'petal_len', 'petal_wid','species']6 df["species"] = df["species"].apply(lambda x: x.replace("Iris-",""))7 #hist()方法繪制直方圖

8 plt.hist(df["sepal_wid"], bins =20, color = "k")9 plt.show()

1469712-20181001214656072-1738441111.png

#修改為累加直方圖, 透明度為0.7

plt.hist(df["sepal_wid"], bins =20, color = "K", cumulative=True, alpha = 0.7)

1469712-20181001215101492-748616885.png

參考資料:

https://www.cnblogs.com/dev-liu/p/pandas_plt_basic.html

https://blog.csdn.net/qq_29721419/article/details/71638912

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/457928.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/457928.shtml
英文地址,請注明出處:http://en.pswp.cn/news/457928.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SPI通訊協議

SPI:高速同步串行口。是一種標準的四線同步雙向串行總線。 SPI,是英語Serial Peripheral interface的縮寫,顧名思義就是串行外圍設備接口。是Motorola首先在其MC68HCXX系列處理器上定義的。SPI接口主要應用在 EEPROM,FLASH&#x…

基于MVVM的知乎日報應用安卓源碼

使用data binding , dagger2 , retrofit2和rxjava實現的&#xff0c;基于MVVM的知乎日報APP運行效果&#xff1a; <ignore_js_op> 使用說明&#xff1a; 項目結構android data binding來實現MVVM。dagger2來完成依賴注入。retrofit2rxjava實現restful的http請求。第三方類…

F#創建者Don Syme談F#設計原則

在.Net Fringe 2016大會上&#xff0c;F#創建者Don Syme談了他對F#現狀的看法以及F#的二元性。F#是以一個為面向對象語言構建的運行時為基礎構建的函數式語言。\\F#是2010年發布的&#xff0c;遵循開源許可協議。F#比.Net更早地踏上了開源之路&#xff0c;C#和.Net在2015年才開…

php簽入html出來的影響seo嗎_搜索引擎優化_SEO必備6大技能+SEO誤區講解!

大家好&#xff0c;我是逆冬&#xff0c;今天來分享一下實戰SEO需要掌握什么樣的技能以及SEO知識誤區&#xff0c;本篇文章僅代表逆冬本人幾年的經驗、不見得適合每一個SEOer!下面就讓逆冬本人來分析一下實戰型SEO到底需要掌握什么技能。第1點&#xff1a;SEO需要不需要熟練掌握…

編寫linux驅動程序步驟

一、建立Linux驅動框架&#xff08;裝載、卸載Linux驅動&#xff09; Linux內核在使用驅動時首先要裝載驅動&#xff0c;在裝載過程中進行一些初始化動作&#xff08;建立設備文件、分配內存等&#xff09;&#xff0c;在驅動程序中需提供相應函數來處理驅動初始化工作&#xf…

一種M2M業務的架構及實現M2M業務的方法

http://www.cnblogs.com/coryxie/p/3849764.html 技術領域 [0001] 本發明涉及通信技術領域&#xff0c;尤其涉及一種M2M業務的架構及實現M2M業務的方法。 背景技術 [0002] 隨著通信技術的飛速發展以及通信技術與互聯網技術的進一步融合&#xff0c;移動業務以及移動互聯網技術普…

第二章 mybatis使用注解實現in查詢(mysql)

mybatis實現in查詢&#xff0c;兩種方法&#xff1a; xml形式&#xff08;推薦&#xff09;注解方式&#xff08;個人喜歡注解&#xff0c;但是in場景可能不太適合注解&#xff09;代碼&#xff1a; 1 Select("<script>" 2 "SELECT ID…

python面試代碼題_python面試基礎篇80題

1.為什么學習python?3.Python和Java、PHP、C、C#、C等其他語言的對比&#xff1f; C語言由于其底層操作特性和歷史的積累&#xff0c;在嵌入式領域是當之無愧的王者。 PHP跨平臺&#xff0c;性能優越&#xff0c;跟linux/unix結合比跟windows結合性能強45%,開發成本低,php5已經…

主設備號與次設備號以及申請

一個字符設備或者塊設備都有一個主設備號和次設備號。主設備號和次設備號統稱為設備號。主設備號用來表示一個特定的驅動程序。次設備號用來表示使用該驅動程序的各設備。例如一個嵌入式系統&#xff0c;有兩個LED指示燈&#xff0c;LED燈需要獨立的打開或者關閉。那么&#xf…

javascript 變量作用域

為什么80%的碼農都做不了架構師&#xff1f;>>> javascript中的變量的作用域不同于java/c的變量規則。 1、在java/c中&#xff0c;如果有一個全局變量與一個局部變量重名&#xff0c;那么在局部變量的作用域中&#xff0c;局部變量會覆蓋掉全局變量的值。當離開局部…

七月算法--12月機器學習在線班-第五次課筆記—回歸

七月算法--12月機器學習在線班-第五次課筆記—回歸 七月算法&#xff08;julyedu.com&#xff09;12月機器學習在線班學習筆記 http://www.julyedu.com 轉載于:https://www.cnblogs.com/sweet-dew/p/5491271.html

集合添加元素python_Python基礎:列表、字典、元組、集合、添加和刪除元素,增刪...

列表&#xff08;有序&#xff09; 添加 list.append(元素)&#xff1a;在列表末尾添加新的元素 list.extend(seq)&#xff1a;在列表末尾一次性追加另一個序列中的多個值 –seq可以是列表、元組、字典&#xff0c;若為字典,則僅會將鍵(key)作為元素依次添加至原列表的末尾。 l…

file_operations結構體分析 (設備文件的操作)

linux設備驅動中file_operations結構體分析 struct module *owner第一個 file_operations 成員根本不是一個操作; 它是一個指向擁有這個結構的模塊的指針. 這個成員用來在它的操作還在被使用時阻止模塊被卸載. 幾乎所有時間中, 它被簡單初始化為 THIS_MODULE, 一個在 <Linux…

公司網絡搭建及×××到公司配置

一、公司路由器及子網配置公司192.168.1.0/24子網用于服務器集群&#xff0c;192.168.0.0/24子網用于辦公子網&#xff0c;兩個子網物理上不在一塊。公司開業時&#xff0c;申請了電信40Mbps專線光纖&#xff0c;5個IP地址&#xff0c;網關&#xff1a;*.168.112.9 255.255.25…

js——全選框 checkbox

一直會碰見input 全選框的問題&#xff0c;先整理一種情況&#xff1a; 1. <input id"selectAll" type"checkbox" />全選 2. <input typecheckbox idid1 namecb value1 />value1 <input typecheckbox idid2 namecb value2 />value2 &…

手機編寫python程序_Python實現自動上京東搶手機

本文實例為大家分享了Python自動上京東搶手機的具體代碼&#xff0c;供大家參考&#xff0c;具體內容如下 上次搶榮耀V9&#xff0c;被京東給惡心到了&#xff0c;所以就寫了個簡單的Python來自動搶V9。雖然用的是比較蠢的方法&#xff0c;但覺得還是有可以學習的地方。所以在這…

struct cdev結構體和cdev_init和cdev_add函數

在Linux內核2.6版本以前&#xff0c;注冊一個字符設備的的經典方法是使用register_chrdev&#xff0c;相應的從設備中注銷字符設備的方法是unregister_chrdev&#xff0c;而在2.6版本以后&#xff0c;字符設備函數的注冊與注銷使用的是如下一套方法&#xff1a; #include<li…

藍鷗零基礎學習HTML5第五講 CSS的基礎樣式

藍鷗零基礎學習HTML5第五講 CSS的基礎樣式1.border<!DOCTYPE html><html lang"en"><head><meta charset"UTF-8"><title>Document</title><style>div {width:0px;height:0px;/*background: url("img/1.jpg…

class_create()函數

內核中定義了struct class結構體&#xff0c;一個struct class 結構體類型變量對應一個類&#xff0c;內核同時提供了class_create()函數&#xff0c;可以用它來創建一個類&#xff0c;這個類存放于sysfs下面&#xff0c;一旦創建了這個類&#xff0c;再調用device_create()函數…

C# 使用Conditional特性而不是#if條件編譯

概述 #if/#endif 語句常用來基于同一份源碼生成不同的編譯結果&#xff0c;其中最常見的就是debug版和release版。但是這些工具在實際應用中并不是非常友好&#xff0c;因為它們容易被濫用&#xff0c;其代碼頁進而難以理解或調試。C#設計中考慮到這個問題&#xff0c;并提供了…