Python项目之中国数据可视化

news/2024/5/24 0:53:02/

文章目录

  • 关键词
  • 一、做什么
  • 二、怎么做
    • 1、获取数据&&处理数据
    • 2、数据库设计&&存储数据
    • 3、开发后端接口
    • 4、前端页面编写
  • 三、效果展示
  • 四、总结


关键词

  • Python
  • Django
  • Python网络爬虫
  • echarts可视化
  • 阅读者(Python基础、Django基础、H5基础)

一、做什么

国家数据十年数据
教育、文化、体育、财政…

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、怎么做

1、获取数据&&处理数据

分析网页数据 | 接口

  • 接口
  • 未加密

在这里插入图片描述
在这里插入图片描述

通过构造请求即可获取数据

import requestsurl = "https://data.stats.gov.cn/easyquery.htm?m=QueryData&dbcode=hgnd&rowcode=zb&colcode=sj&wds=%5B%5D&dfwds=%5B%7B%22wdcode%22%3A%22zb%22%2C%22valuecode%22%3A%22A0M0101%22%7D%5D&k1=1681802150380&h=1"payload={}
headers = {'Accept': 'application/json, text/javascript, */*; q=0.01','Accept-Language': 'en,zh-CN;q=0.9,zh;q=0.8','Cache-Control': 'no-cache','Connection': 'keep-alive','Cookie': '_trs_uv=lb3ivyja_6_9rxg; wzws_sessionid=gWQ5YzU0NIAyNDA5OjhhMzg6YzBhOjU3Yjg6NDA3Ojk4OTc6ZmJkZTpkODE1oGQ+OquCZmM1ZWUx; u=6; JSESSIONID=nhaTNEtX-UbYOP07UUOERWA20RlZhKPfyIJOXPgdpF5X26gOalzB!1171792879','Pragma': 'no-cache','Referer': 'https://data.stats.gov.cn/easyquery.htm?cn=C01','Sec-Fetch-Dest': 'empty','Sec-Fetch-Mode': 'cors','Sec-Fetch-Site': 'same-origin','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/112.0.0.0 Safari/537.36','X-Requested-With': 'XMLHttpRequest','sec-ch-ua': '"Chromium";v="112", "Google Chrome";v="112", "Not:A-Brand";v="99"','sec-ch-ua-mobile': '?0','sec-ch-ua-platform': '"Windows"'
}response = requests.request("GET", url, headers=headers, data=payload)print(response.text)

在这里插入图片描述

处理response
我们要获取的数据有
datanodes[i].data.data 年度数据
wdnodes[i].nodes.cname 数据名称
wdnodes[i].nodes.unit 单位

# 文件名称  get_national_data.py
# -*- encoding:utf-8 -*-
__author__ = "Nick"
__created_date__ = "2023/04/18"import requests
import json
import pymysql
import timeimport urllib3
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)# 忽视ignore错误import randomheaders = {'Accept': 'application/json, text/javascript, */*; q=0.01','Cookie': '_trs_uv=lb3ivyja_6_9rxg; wzws_sessionid=gTc5MmRlNaBjiV2ZgmZjNWVlMYAyNDA5OjhhMzg6YzBhOmNlNDE6NDA3Ojk4OTc6ZmJkZTpkODE1; u=2; JSESSIONID=JdPTM5JOti-gtAt3y4OxewoNkDOizREzxPdkiYzr1HkaEoOXtsDc!2123879546','Pragma': 'no-cache','Referer': 'https://data.stats.gov.cn/easyquery.htm?cn=C01','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36','X-Requested-With': 'XMLHttpRequest',
}# 获取国家统计局数据
class Get_national_data():def __init__(self,url,fld,sld_name):"""@param url 请求url@param fld 一级目录缩写@param sld 二级目录category_name_two缩写"""# 数据接口urlself.url = url# 一级目录self.fid = fld# 二级目录self.sld_name = sld_namedef get_request(self):"""发起请求"""payload = {}# 国家统计局证书已过期,verify=Falsetime.sleep(3)r = requests.request("GET", url=self.url, headers=headers, data=payload, verify=False)r.encoding = "utf-8"res = json.loads(r.text.encode("utf-8"))self.res = resdef count_cname(self):"""统计二级目录下指标数量@return 二级目录下指标个数"""# 获取单位unit = self.res["returndata"]["wdnodes"][0]["nodes"][0]["unit"]self.unit = unitnames_list = self.res["returndata"]["wdnodes"][0]["nodes"]index_name = []for name in names_list:_name = name["name"]index_name.append(_name)return len(index_name)def get_original_data_name(self):"""获取二级目录下的指标名称通过 yield 函数每次获取一个名称"""# 二级目下具体指标name获取names_list = self.res["returndata"]["wdnodes"][0]["nodes"]index_name = []for name in names_list:_name = name["name"]index_name.append(_name)if len(index_name) == 1:yield index_nameindex_name = []def get_original_data(self):"""获取二级目录下具体的数据通过yield 每次获取取10个值"""# 数据获取data_list = self.res["returndata"]["datanodes"]# 定义存储容器process_data = []for data in data_list:info = data["data"]["data"]process_data.append(info)if len(process_data) == 10:# 迭代器,一次获取10数据yield process_dataprocess_data = []def get_data_10(self, data, data_name):"""获取一组值@param data get_original_data实例化获取@param data_name get_original_data_name 实例化获取@return 返回一组数据,元祖类型"""# cname获取cname = data_name.__next__()[0]self.cname = cname# 查询nameself.select_cname_id()# 十条数据获取last_data = data.__next__()# 添加cnamelast_data.insert(0,cname)# 添加一级、二级目录last_data.extend([self.unit, self.fid , self.sid_id])return tuple(last_data)def connect_db(self):"""连接数据库@return 数据库实例化"""connect = pymysql.connect(host="localhost",port=3306,user='root',password='rootroot',database='tenchina')return connect# 查询SQLdef select_cname_id(self):# 查询cname的idconnect = self.connect_db()# 实例化cursor = connect.cursor()# 查询try:sql_id = f"""select id from tb_category_two where category_name_two = {self.sld_name}"""cursor.execute(sql_id)result = cursor.fetchone()connect.commit()connect.close()self.sid_id = result[0]except Exception as e:print(e)if __name__ == '__main__':pass

2、数据库设计&&存储数据

Django中通过model.py定义数据字段即可完成表的设计

from django.db import models# Create your models here."""
建立三张表
1、tb_category_one 一级目录表
2、tb_category_two 二级目录表
3、数据表 
"""# 分类表、一级目录
class category_one(models.Model):# 分类名称(教育、文化、体育等)category_name = models.CharField(max_length=10)# 数据库表名为t_categoryclass Meta:db_table = "tb_category_one"# 分类表、二级目录
class category_two(models.Model):# 分类名称-教育(各级学校数)、-文化(博物馆)category_name_two = models.CharField(max_length=40)# 建立一对多的关系specific = models.ForeignKey(to=category_one,related_name="specific", on_delete=models.CASCADE)# 数据库表名class Meta:db_table = "tb_category_two"class detail(models.Model):# 分类具体名称name = models.CharField(max_length=30)# 年度2021year_2021 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2020year_2020 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2019year_2019 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2018year_2018 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2017year_2017 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2016year_2016 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2015year_2015 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2014year_2014 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2013year_2013 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 年度2012year_2012 = models.DecimalField(max_digits=12,decimal_places=4,null=True)# 单位unit = models.CharField(max_length=10)# 建立一对多的关系category_1 = models.ForeignKey(to=category_one,related_name="category_list_1",on_delete=models.CASCADE)# 建立一对多的关系category_2 = models.ForeignKey(to=category_two, related_name="category_list_2", on_delete=models.CASCADE)# 数据库表名为t_detailclass Meta:db_table = "tb_detail"

数据迁移
记得setting.py配置MySQL数据库,并新建相关数据库
python manage.py makemigrations
python manage.py migrate

3、开发后端接口

1、view.py 编写视图函数
2、url.py 定义相关路由

# 分离SQL语句
def create_sql(table_name,category_id):_sql = f"select DISTINCT id,name,year_2021,year_2020,year_2019,year_2018,year_2017,year_2016,year_2015,year_2014,year_2013,year_2012,unit from {table_name} where category_2_id = {category_id} LIMIT 6;"return _sql
# 教育模块
def education_select(request,num):"""@param request:@param num: 1-各级各类学校数处理、2-各级各类学校专任教师数处理、3-各级各类学校毕业生数处理、4-研究生和留学生数处理@return:Json数据,Echarts拿到数据回显"""# 定义十年数据data = ['2021', '2020', '2019', '2018', '2017', '2016', '2015', '2014', '2013', '2012']# 定义index_list存储index_name(普通学校数、普通中学数、普通高中学校数等)index_list = []# 接口返回特定格式的数据series_list = []# data_2021-2012data_2021 = []data_2020 = []data_2019 = []data_2018= []data_2017 = []data_2016 = []data_2015 = []data_2014 = []data_2013 = []data_2012 = []if num == "1":sql = create_sql(table_name="tb_detail",category_id=1)elif num == "2":sql = create_sql(table_name="tb_detail",category_id=2)elif num == "3":sql = create_sql(table_name="tb_detail", category_id=5)elif num == "4":sql = create_sql(table_name="tb_detail", category_id=6)# 原生查询ret = detail.objects.raw(sql)for item in ret:index_list.append(item.name)data_2021.append(item.year_2021)data_2020.append(item.year_2020)data_2019.append(item.year_2019)data_2018.append(item.year_2018)data_2017.append(item.year_2017)data_2016.append(item.year_2016)data_2015.append(item.year_2015)data_2014.append(item.year_2014)data_2013.append(item.year_2013)data_2012.append(item.year_2012)#构建2021-2012for i in range(21, 11, -1):year = f"20{i}"series_dict = {'name': year,'type': 'line','stack': 'Total','data': ''}if year == "2021":series_dict["data"] = data_2021elif year == "2020":series_dict["data"] = data_2020elif year == "2019":series_dict["data"] = data_2019elif year == "2018":series_dict["data"] = data_2018elif year == "2017":series_dict["data"] = data_2017elif year == "2016":series_dict["data"] = data_2016elif year == "2015":series_dict["data"] = data_2015elif year == "2014":series_dict["data"] = data_2014elif year == "2013":series_dict["data"] = data_2013elif year == "2012":series_dict["data"] = data_2012else:passif num == "1":# 各级各类学校数passelif num == "2":# 各级各类学校专任教师数focus ={"focus": 'series'}series_dict["emphasis"] = focusseries_dict["areaStyle"] = "{}"elif num == "3":series_dict["type"] = "bar"focus = {"focus": 'series'}series_dict["emphasis"] = focusseries_dict["stack"] = 'Ad'elif num == "4":series_dict["type"] = 'bar'show ={"show": "true"}series_dict["label"] = showseries_list.append(series_dict)# 最后返回的数据格式result = {"status": True,"data":{"legend": data,"xAxis": index_list,"series_list": series_list,}}return JsonResponse(result)def chart_three(request):"""各级各类学校招生数@param request:@return: Json数据,Echarts拿到数据回显"""# 定义格式source = []data = ['year', '2021', '2020', '2019', '2018', '2017','2016', '2015', '2014', '2013','2012']source.append(data)# 查询sql = create_sql(table_name="tb_detail", category_id=3)# 原生查询ret = detail.objects.raw(sql)for item in ret:data_list = []data_list.extend([item.name,item.year_2021,item.year_2020,item.year_2019,item.year_2018,item.year_2017,item.year_2016,item.year_2015,item.year_2014,item.year_2013,item.year_2012])source.append(data_list)# 最后返回的数据格式result = {"status": True,"data": source}return JsonResponse(result)def chart_four(request):"""各级各类学校在校学生数@param request:@return:Json数据,Echarts拿到数据回显"""# 定义格式dataset = {}# 年限定义dataset["dimensions"] = ['product', '2021', '2020', '2019', '2018', '2017','2016']#source_list = []# 查询sql = create_sql(table_name="tb_detail", category_id=4)# 原生查询ret = detail.objects.raw(sql)for item in ret:# 把数据为空的剔除if item.year_2021:source_dict = {}source_dict["product"] = item.namesource_dict["2021"] = item.year_2021source_dict["2020"] = item.year_2020source_dict["2019"] = item.year_2019source_dict["2018"] = item.year_2018source_dict["2017"] = item.year_2017source_dict["2016"] = item.year_2016source_list.append(source_dict)dataset["source"] = source_listresult = {"status": True,"data": dataset}return JsonResponse(result)
from django.urls import path,re_pathfrom . import views as vurlpatterns = [# 教育模块# path('/educate',v.education_select),re_path(r'^educate/(\d+)$',v.education_select),path('educate/chart3',v.chart_three),path('educate/chart4',v.chart_four),# 文化模块re_path(r'^culture/(\d+)$',v.culture_select),path('culture/chart3',v.chart_three_culture),path('culture/chart4',v.chart_four_culture),# 体育模块re_path(r'^pe/(\d+)$',v.pe_select),path('pe/chart3',v.chart_three_pe),path('pe/chart4',v.chart_four_pe),]

4、前端页面编写

省略相关js、css文件,见代码仓库
base.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><link rel="stylesheet" href="../static/css/main.css" /><title>{{ title }}</title></head><body><div class="nav_menu w"><div class="menu_item"><div class="home">教育</div><div class="web_home"><a href="http://127.0.0.1:8000/index">教育首页</a></div></div><div class="menu_item"><div class="home">文化</div><div class="web_home"><a href="http://127.0.0.1:8000/culture">文化首页</a></div></div><div class="menu_item"><div class="home">体育</div><div class="web_home"><a href="http://127.0.0.1:8000/pe">体育首页</a></div></div><div class="menu_item"><div class="home">财政</div><div class="web_home"><a href="#">财政首页</a></div></div><div class="menu_item"><div class="home">人民生活</div><div class="web_home"><a href="#">人民生活</a></div></div><div class="menu_item"><div class="home">科技</div><div class="web_home"><a href="#">科技首页</a></div></div><div class="menu_item"><div class="home">卫生</div><div class="web_home"><a href="#">卫生首页</a></div></div><div class="menu_item"><div class="home">社会</div><div class="web_home">社会首页</div></div></div><nav class="menu"><ol><li id="content1" class="menu-item active"><a href="javascript:void(0);">{{ category_content.0}}</a></li><li id="content2" class="menu-item"><a href="javascript:void(0);">{{category_content.1 }}</a></li><li id="content3" class="menu-item"><a href="javascript:void(0);">{{category_content.2 }}</a></li><li id="content4" class="menu-item"><a href="javascript:void(0);">{{ category_content.3 }}</a></li><li id="content5" class="menu-item"><a href="javascript:void(0);">{{category_content.4 }}</a></li><li id="content6" class="menu-item"><a href="javascript:void(0);">{{ category_content.5 }}</a></li></ol></nav><div class="container-div"><!-- 各级各类学校 --><div class="text content1" id="container"></div><!-- 各级各类学校专任教师数 --><div class="text content2" id= "container1"></div><!-- 各级各类学校招生数 --><div class="text content3" id ="container2"></div><!-- 各级各类学校在校学生数 --><div class="text content4" id="container3"></div><!-- 各级各类学校毕业生数 --><div class="text content5" id = "container4"></div><!-- 研究生和留学生数 --><div class="text content6" id="container5"></div></div><script src="https://www.jq22.com/jquery/jquery-1.10.2.js"></script>{% block tojs %}{% endblock %}<script type="text/javascript" src="https://fastly.jsdelivr.net/npm/echarts@5.4.0/dist/echarts.min.js"></script></body>
</html>

educate.html

{% extends "base.html" %}<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title></title>
</head>
<body>{% block tojs %}<script src="../static/js/index.js"></script>{% endblock %}</body>
</html>

三、效果展示

在这里插入图片描述

四、总结

  • 过于混杂(之后会进行改造)
  • 数据分析过于单一(数据可视化为的是更好的展示结论)

[gitee]
https://gitee.com/nickwang666/visual-ten-china

在这里插入图片描述


http://www.ppmy.cn/news/47671.html

相关文章

vue3插槽的使用

插槽就是子组件中的提供给父组件使用的一个占位符&#xff0c;用 表示&#xff0c;父组件可以在这个占位符中填充任何模板代码&#xff0c;如 HTML、组件等&#xff0c;填充的内容会替换子组件的标签。 1.插槽基本使用 子组件SlotComponent.vue <template><div cla…

【计算机专业应届生先找培训还是先找个工作过渡一下?】

计算机专业应届生先找培训还是先找个工作过渡一下&#xff1f; 计算机应届生是先培训还是先工作&#xff0c;这个问题应该困扰了很多专业技能一般的同学&#xff0c;尤其是学历方面还没有优势的普通本专科院校。都说技术与学历优秀的人进大厂&#xff0c;技术一般学历优秀的人能…

树莓派 QT项目开机自启动

我自己用qt设置了一个界面&#xff0c;如何让他开机自启动呢&#xff1f; 目录 1.生成qt项目的可执行文件 2. 编写一个自启动脚本 3.重启树莓派 1.生成qt项目的可执行文件 QT项目的可执行文件就是.exe文件。首先在qt中打开&#xff0c;点击红色方框图标&#xff0c;选择Re…

IO进程间的通信详解(嵌入式学习)

进程间通信 这次更新内容比较干巴&#xff0c;满满嚼&#xff0c;把例子敲一遍好好理解。如果您着急&#xff0c;请直接打开目录跳转到对您有价值的部分管道无名管道(PIPE)特点使用方法举个栗子 有名管道(FIFO)特点使用方法举个栗子 信号概念响应方式信号函数举个栗子&#xff…

冯诺依曼体系结构+操作系统

目录 冯诺依曼体系结构 基本概念 基本原理 操作系统 基本概念 设计OS的目的 管理的本质 管理的方法 系统调用和库函数 冯诺依曼体系结构 基本概念 冯诺依曼结构也称普林斯顿结构&#xff0c;是一种将程序指令存储器和数据存储器合并在一起的存储器结构。 ... 数学…

24个强大的HTML属性,建议每位前端工程师都应该掌握!

HTML属性非常多&#xff0c;除了一些基础属性外&#xff0c;还有许多有用的特别强大的属性 本文将介绍24个强大的HTML属性&#xff0c;可以使您的网站更具有动态性和交互性&#xff0c;让用户感到更加舒适和愉悦。 让我们一起来探索这24个强大的HTML属性吧&#xff01; 1、Acc…

js+css实现简单的弹框动画

效果图 只是一个简单的演示demo&#xff0c;但是可以后面可以优化样式啥的 刚开始元素的display为none&#xff0c;然后&#xff0c;为了给元素展示时添加一个动画&#xff0c;首先要添加样式类名show&#xff0c;让它覆盖display:none&#xff0c;变得可见。然后&#xff0c;添…

docker+jenkins+maven+git构建聚合项目,实现自动化部署,走了800个坑

流程 主要的逻辑就是Docker上安装jenkins&#xff0c;然后拉取git上的代码&#xff0c;把git上的代码用Maven打包成jar包&#xff0c;然后在docker运行 这个流程上的难点 一个是聚合项目有可能Maven install的时候失败。 解决办法&#xff1a;在基础模块的pom文件上添加 <…

【数据结构】堆的应用(堆排序的实现 + (向上/向下)建堆时间复杂度证明 + TopK问题(笔记总结))

&#x1f466;个人主页&#xff1a;Weraphael ✍&#x1f3fb;作者简介&#xff1a;目前学习C和算法 ✈️专栏&#xff1a;数据结构 &#x1f40b; 希望大家多多支持&#xff0c;咱一起进步&#xff01;&#x1f601; 如果文章对你有帮助的话 欢迎 评论&#x1f4ac; 点赞&…

Flink Table API 和 Flink-SQL使用详解

Flink Table API 和 Flink-SQL使用详解 1.Table API & Flink SQL-核心概念 ​ Apache Flink 有两种关系型 API 来做流批统一处理&#xff1a; Table API Table API 是用于 Scala 和 Java 语言的查询API&#xff0c;它可以用一种非常直观的方式来组合使用选取、过滤、join…

RK3568平台开发系列讲解(调试篇)IS_ERR函数的使用

🚀返回专栏总目录 文章目录 一、IS_ERR函数用法二、IS_ERR函数三、内核错误码沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇将介绍 IS_ERR 函数的使用。 一、IS_ERR函数用法 先看下用法: 二、IS_ERR函数 对于任何一个指针来说,必然存在三种情况: 一种是合…

电源常识-PCB材质防火等级焊锡工艺

1、目前主流的PCB材质分类主要有以下几种,如图1&#xff0c;图2&#xff0c;图3。FR-4材质比CEM-1好&#xff0c;CEM-1比FR-1好。 按结构分为单面板&#xff0c;双面板&#xff0c;多层板。单面板就是单面铺铜走线&#xff0c;双面板就是上下两面都可以铺铜走线&#xff0c;多层…

Guns社区医疗项目

又是一年毕业季&#xff0c;计算机专业大四的同学们要接受毕业设计的考验啦。又有多少同学为了毕业设计而愁眉苦脸&#xff0c;心力憔悴。考虑到这些&#xff0c;这里为同学们分享一个适合你们毕业设计的作品以及详细介绍&#xff0c;让正在焦头烂额的同学们有所启发&#xff0…

asp.net+C#房地产销售系统文献综述和开题报告+Lw

本系统使用了B/S模式&#xff0c;使用ASP.NET语言和SQL Server来设计开发的。首先把所有人分为了用户和管理员2个部分&#xff0c;一般的用户可以对系统的前台进行访问&#xff0c;对一般的信息进行查看&#xff0c;而注册用户就可以通过登录来完成对房屋信息的查看和对房屋的…

开发插件JFormDesigner(可视化GUI编程)的使用与注册-简单几步即可完成

开发插件JFormDesigner&#xff08;可视化GUI编程&#xff09;的使用与注册 获取链接&#xff1a;1.JFormDesigner获取2.记录插件下载路径3.使用zcj注册4.生成license5.打开idea进行注册 获取链接&#xff1a; https://pan.baidu.com/s/1N9ua2p3BpiMIARCEewRxIw?pwd4e9a 提取…

浅说情绪控制被杏仁体劫持

2023年4月16号&#xff0c;没想到被杏仁体劫持那么严重&#xff0c;触发手抖和口干的症状&#xff0c;这个还真是自己完全没有意识到的【这就是焦虑固化的记忆会持续化】。 【修行】人生要修炼两条线&#xff1a;一条明线是做的事情&#xff0c;那是自己要做的具体事情。 一条…

天梯赛 L2-034 口罩发放

原题链接&#xff1a; PTA | 程序设计类实验辅助教学平台 题目描述&#xff1a; 为了抗击来势汹汹的 COVID19 新型冠状病毒&#xff0c;全国各地均启动了各项措施控制疫情发展&#xff0c;其中一个重要的环节是口罩的发放。 某市出于给市民发放口罩的需要&#xff0c;推出了…

python-day6(补充三:实例变量和函数)

实例变量和函数 实例函数的定义认识__init__函数定义实例变量实例函数中访问实例变量外部访问实例变量与函数 实例函数的定义 定义实例函数 class Student:def say_hello(self, msg):print(f"hello{msg}")实例函数属于对象 class Student:def say_hello(self, m…

JMM之volatile关键字详解

1、概要 在JMM规范下有三大特性分别是&#xff1a;可见性、原子性、有序性。而被volatile关键字修饰的共享变量拥有三大特性的两大特性分别是&#xff1a;可见性和有序性。 为什么被volatile修饰的变量就可以保证变量的可见性和有序性呢&#xff1f;为啥不能保证原子性&#…

使用 PyTorch Geometric 和 GCTConv实现异构图、二部图上的节点分类或者链路预测

解决问题描述 使用 PyTorch Geometric 和 Heterogeneous Graph Transformer 实现异构图上的节点分类 在二部图上应用GTN算法(使用torch_geometric的库HGTConv)&#xff1b; 步骤解释 导入所需的 PyTorch 和 PyTorch Geometric 库。 定义 x1 和 x2 两种不同类型节点的特征&am…