哪些网站用python做的网页是怎么制作的

news/2025/10/4 23:46:53/文章来源:
哪些网站用python做的,网页是怎么制作的,装修公司做网销的网站,pyton怎么做网站的代码本博客为个人学习笔记#xff0c;学习网站#xff1a;黑马程序员SpringCloud 2021教程 目录 DSL语法 索引库操作 mapping属性 创建索引库 字段拷贝 查询、删除、修改索引库 文档操作 新增文档 查询、删除文档 修改文档 全量修改 增量修改 DSL文档语法小结 Rest… 本博客为个人学习笔记学习网站黑马程序员SpringCloud 2021教程 目录 DSL语法 索引库操作 mapping属性 创建索引库 字段拷贝  查询、删除、修改索引库 文档操作 新增文档 查询、删除文档 修改文档 全量修改 增量修改 DSL文档语法小结 RestClient操作 初始化RestClient 索引库操作 RestClient创建索引库 RestClient删除索引库 RestClient判断索引库是否存在 文档操作 RestClient新增文档 RestClient查询文档 RestClient修改文档 全量修改 增量修改 RestClient删除文档 RestClient批量新增文档 RestClient文档操作小结 DSL语法 索引库操作 mapping属性 mapping是对索引库中文档的约束常见的mapping属性包括 1. type字段数据类型常见的简单类型有         字符串text可分词的文本、keyword精确值例如品牌、国家、ip地址、分词无意义的值         数值long、integer、short、byte、double、float         布尔boolean         日期date         对象object 2. index是否创建索引默认为true 3. analyzer使用哪种分词器 4. properties该字段的子字段 创建索引库 示例 按以下json文档的字段创建一个索引库 {age: 21,weight: 52.1,isMarried: false,info: 黑马程序员Java讲师,email: zyitcast.cn,score: [99.1, 99.5, 98.9],name: {firstName: 云,lastName: 赵} } 创建索引库DSL语句如下 # 创建索引库 PUT /heima {mappings: {properties: {info:{type: text,analyzer: ik_smart},email:{type: keyword,index: false},name:{type: object,properties: {firstName:{type: keyword},lastName:{type:keyword}}}}} } 字段拷贝  如果在查询文档时想要同时基于多个字段进行查询那么在创建索引库时可以把这些字段通过copy_to拷贝到另外一个字段all中在之后的搜索中直接搜索all字段即可。而且all字段在查询得到的结果文档中是不会显示出来的但是在查询的时候会提示可以查询all字段。 查询、删除、修改索引库 查询索引库 #语法 GET /索引库名#示例如下 GET /heima 删除索引库 #语法如下 DELETE /索引库名#示例如下 DELETE /heima 修改索引库         倒排索引结构虽然不复杂但是一旦数据结构改变比如改变了分词器就需要重新创建倒排索引这简直是灾难。因此索引库一旦创建就无法修改mapping。虽然无法修改mapping中已有的字段但是却允许添加新的字段到mapping中因为这样不会对倒排索引产生影响。 新增字段 #语法如下 PUT /索引库名/_mapping {properties: {新字段名:{type: integer}} }#示例如下(新字段名必须和存在的字段名不同) PUT /heima/_mapping {properties:{age:{type:long}} } 文档操作 新增文档 #语法如下 POST /索引库名/_doc/文档id {字段1: 值1,字段2: 值2,字段3: {子属性1: 值3,子属性2: 值4},// ... }#示例如下 POST /heima/_doc/1 {info: 黑马程序员Java讲师,email: zyitcast.cn,name: {firstName: 云,lastName: 赵} } 查询、删除文档 查询文档 #语法如下 GET /{索引库名称}/_doc/{id}#示例如下 GET /heima/_doc/1 删除文档 #语法如下 DELETE /{索引库名}/_doc/id值#示例如下根据id删除文档 DELETE /heima/_doc/1 修改文档 修改文档有两种方式: 1. 全量修改:直接覆盖原来的文档 2. 增量修改:修改文档中的部分字段  全量修改 全量修改是覆盖原来的文档其本质是先根据指定的id删除文档再新增一个相同id的文档注意如果根据id删除时id不存在第二步的新增也会执行也就从修改变成了新增操作了。 #语法如下 PUT /{索引库名}/_doc/文档id {字段1: 值1,字段2: 值2,// ... 略 }#示例如下 PUT /heima/_doc/1 {info: 黑马程序员高级Java讲师,email: zyitcast.cn,name: {firstName: 云,lastName: 赵} } 增量修改 增量修改是只修改指定id匹配的文档中的部分字段。 #语法如下 POST /{索引库名}/_update/文档id {doc: {字段名: 新的值,} }#示例如下 POST /heima/_update/1 {doc: {email: ZhaoYunitcast.cn} } DSL文档语法小结 创建文档POST/(索引库名}/_doc/文档id {json文档} 查询文档GET /(索引库名}/_doc/文档id 删除文档DELETE /(索引库名}/_doc/文档id 修改文档         全量修改PUT /(索引库名}/doc/文档id {json文档 }         增量修改POST/{索引库名}/_update/文档id {“doc:{字段}} RestClient操作 初始化RestClient 在elasticsearch提供的API中与elasticsearch一切交互都封装在一个名为RestHighLevelClient的类中必须先完成这个对象的初始化建立与elasticsearch的连接。 步骤1. 引入es的RestHighLevelClient依赖 dependencygroupIdorg.elasticsearch.client/groupIdartifactIdelasticsearch-rest-high-level-client/artifactId /dependency 步骤2. 因为SpringBoot默认的ES版本是7.6.2所以我们需要覆盖默认的ES版本 propertiesjava.version1.8/java.versionelasticsearch.version7.12.1/elasticsearch.version /properties 步骤3. 初始化RestHighLevelClient代码如下 RestHighLevelClient client new RestHighLevelClient(RestClient.builder(HttpHost.create(http://192.168.150.101:9200) )); 步骤4. 这里为了单元测试方便我们创建一个测试类HotelIndexTest然后将初始化的代码编写在BeforeEach方法中 package cn.itcast.hotel;import org.apache.http.HttpHost; import org.elasticsearch.client.RestHighLevelClient; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test;import java.io.IOException;public class HotelIndexTest {private RestHighLevelClient client;BeforeEachvoid setUp() {this.client new RestHighLevelClient(RestClient.builder(HttpHost.create(http://192.168.150.101:9200)));}AfterEachvoid tearDown() throws IOException {this.client.close();} } 索引库操作 RestClient创建索引库 代码如下  Test void createHotelIndex() throws IOException {// 1.创建Request对象CreateIndexRequest request new CreateIndexRequest(hotel);// 2.准备请求的参数DSL语句request.source(MAPPING_TEMPLATE, XContentType.JSON);// 3.发送请求client.indices().create(request, RequestOptions.DEFAULT); } RestClient删除索引库 Test void testDeleteHotelIndex() throws IOException {// 1.创建Request对象DeleteIndexRequest request new DeleteIndexRequest(hotel);// 2.发送请求client.indices().delete(request, RequestOptions.DEFAULT); } RestClient判断索引库是否存在 Test void testExistsHotelIndex() throws IOException {// 1.创建Request对象GetIndexRequest request new GetIndexRequest(hotel);// 2.发送请求boolean exists client.indices().exists(request, RequestOptions.DEFAULT);// 3.输出System.err.println(exists ? 索引库已经存在 : 索引库不存在); } 文档操作 RestClient新增文档 我们需要将数据库的酒店数据查询出来写入elasticsearch中。而数据库查询后得到的结果是一个Hotel类型的对象。结构如下 Data TableName(tb_hotel) public class Hotel {TableId(type IdType.INPUT)private Long id;private String name;private String address;private Integer price;private Integer score;private String brand;private String city;private String starName;private String business;private String longitude;private String latitude;private String pic; } 由于该对象的结构与elasticsearch索引库结构存在差异因此我们需要定义一个新的类型与索引库结构吻合结构如下 package cn.itcast.hotel.pojo;import lombok.Data; import lombok.NoArgsConstructor;Data NoArgsConstructor public class HotelDoc {private Long id;private String name;private String address;private Integer price;private Integer score;private String brand;private String city;private String starName;private String business;private String location;private String pic;public HotelDoc(Hotel hotel) {this.id hotel.getId();this.name hotel.getName();this.address hotel.getAddress();this.price hotel.getPrice();this.score hotel.getScore();this.brand hotel.getBrand();this.city hotel.getCity();this.starName hotel.getStarName();this.business hotel.getBusiness();this.location hotel.getLatitude() , hotel.getLongitude();this.pic hotel.getPic();} }新增文档语法  从数据库中查询数据并新增到ES文档实现 Test void testAddDocument() throws IOException {// 1.根据id查询酒店数据Hotel hotel hotelService.getById(61083L);// 2.转换为文档类型HotelDoc hotelDoc new HotelDoc(hotel);// 3.将HotelDoc转jsonString json JSON.toJSONString(hotelDoc);// 1.准备Request对象IndexRequest request new IndexRequest(hotel).id(hotelDoc.getId().toString());// 2.准备Json文档request.source(json, XContentType.JSON);// 3.发送请求client.index(request, RequestOptions.DEFAULT); } RestClient查询文档 查询语法 代码如下  Test void testGetDocumentById() throws IOException {// 1.准备RequestGetRequest request new GetRequest(hotel, 61082);// 2.发送请求得到响应GetResponse response client.get(request, RequestOptions.DEFAULT);// 3.解析响应结果String json response.getSourceAsString();HotelDoc hotelDoc JSON.parseObject(json, HotelDoc.class);System.out.println(hotelDoc); } RestClient修改文档 在DSL语法中我们讲过修改文档的两种方式 1. 全量修改本质是先根据id删除再新增 2. 增量修改修改文档中的指定字段值 全量修改 在Restclient的API中全量修改与新增的API完全一致判断依据是ID: 如果新增时ID已存在则修改 如果新增时ID不存在则新增。 全量修改的语法这里不再赘述参考前面的新增文档即可这里我们主要关注增量修改。 增量修改 增量修改语法如下 代码如下 Test void testUpdateDocument() throws IOException {// 1.准备RequestUpdateRequest request new UpdateRequest(hotel, 61083);// 2.准备请求参数request.doc(price, 952,starName, 四钻);// 3.发送请求client.update(request, RequestOptions.DEFAULT); } RestClient删除文档 根据id删除文档代码如下 Test void testDeleteDocument() throws IOException {// 1.准备RequestDeleteRequest request new DeleteRequest(hotel, 61083);// 2.发送请求client.delete(request, RequestOptions.DEFAULT); } RestClient批量新增文档 利用BulkRequest实现批量操作其本质就是将多个普通的CRUD请求组合在一起发送。 其中提供了一个add方法我们可以把IndexRequest(新增)、UpdateRequest(修改)、DeleteRequest(删除) 通过add方法进行添加从而实现批量操作。 示例  利用MP从数据库获取数据并批量新增完整代码  Test void testBulkRequest() throws IOException {// 批量查询酒店数据ListHotel hotels hotelService.list();// 1.创建RequestBulkRequest request new BulkRequest();// 2.准备参数添加多个新增的Requestfor (Hotel hotel : hotels) {// 2.1.转换为文档类型HotelDocHotelDoc hotelDoc new HotelDoc(hotel);// 2.2.创建新增文档的Request对象request.add(new IndexRequest(hotel).id(hotelDoc.getId().toString()).source(JSON.toJSONString(hotelDoc), XContentType.JSON));}// 3.发送请求client.bulk(request, RequestOptions.DEFAULT); } RestClient文档操作小结 文档操作的基本步骤: 1. 初始化RestHighLevelClient 2. 创建XxxRequest。XXX是Index、Get、Update、Delete、Bulk 3. 准备参数(Index、Update、Bulk时需要) 4. 发送请求。调用RestHighLevelClient#.xxx()方法xx是index、get、update、delete、bulk 5. 解析结果(Get时需要)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/927694.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

不用登录的小游戏网站有哪些可以做翻译的网站

【CTSC2017】游戏 problem UOJ299 solution 定义 Xi:X_i:Xi​: 当前已知条件第 iii 局的状态 1/01/01/0(胜/败)。 将 XiCiX_iC_iXi​Ci​ 记为事件 AiA_iAi​。 假设现在已知条件共有 sss 个,即:第 k1∼sk_{1\sim s}k1∼s​…

03-spirngIOC02-通过注解实现IOC

03-spirngIOC02-通过注解实现IOC$(".postTitle2").removeClass("postTitle2").addClass("singleposttitle");通过注解实现IOC实现实体类 package com.zhongge.entity;import jakarta.an…

网站怎么在移动端推广桂林必去五个景点

ON1 Photo RAW 2024 for Mac是一款集专业性与易用性于一体的照片编辑软件。它拥有简洁直观的用户界面,即便对于摄影新手,也能快速上手。软件支持RAW格式照片处理,能够完整保留照片原始信息,让后期调整更加灵活。 在功能方面&#…

网站的运营成本最新人才招聘网

1.0osi七层模型 应用层 data 表示层 会话层 传输层 数据段 防火墙,端口(TCP UDP) 网络层 数据包 路由器 数据链路层 数据帧 交换机 物理层 比特流 网卡 2.IP地址分类 私有地址 A类 0--127 10.0.0.0…

服务之家网站推广公司网站开发属于技术合同

来源:生物通近年来,有一些证据表明,饮食干预有助于减缓肿瘤的生长。麻省理工学院的一项新研究分析了小鼠的两种不同饮食,揭示了这些饮食是如何影响癌细胞的,并为为什么限制卡路里可以减缓肿瘤生长提供了解释。该研究检…

美食网站 怎么做wordpress客户端制作

引言 作为数据传输界鼎鼎大名的扛把子,XML被应用于各个方面,但随着弱结构化标记语言如JSON、YAML等的出现,人们慢慢的脱离了XML的统治,但在互联网早期的发展当中XML是不可或缺的一部分,比如各种微信开发中的数据传输&…

哈希简单解说

Sky Clearing Up这个哈希确实是啊。 这里不说各种冲突什么东西的证明,因为作者不会,看不懂。 你说说是谁把钢琴和弦乐放一块去的,我怎么飞起来了。 哈希 下面的定义都是不严谨的,这里仅是我的通俗解释。 哈希的基本…

02-springIOC01-注解方式实现

02-springIOC01-注解方式实现$(".postTitle2").removeClass("postTitle2").addClass("singleposttitle");使用注解的方式实现IOC 定义两个实体类 /*** @ClassName Address* @Descriptio…

国内买机票的网站建设有啥好玩的网页游戏

简介 TensorFlow是由Google团队开发的一个开源深度学习框架,完全基于Python语言设计。它的初衷是以最简单的方式实现机器学习和深度学习的概念,结合了计算代数的优化技术,使计算许多数学表达式变得简单。 优势: 强大的计算能力…

网站开发的原理西安 房产网站建设

注意:进行实例之前必须完成nginx的源码编译。(阅读往期文章完成步骤) 1.编辑nginx的配置文件,修改内容 [rootlocalhost ~]# vim /usr/local/nginx/conf/nginx.conf 2.创建新目录/usr/local/nginx/conf.d/,编辑新文件…

Say 题选记(9.28 - 10.4)

P5363 [SDOI2019] 移动金币 Staircase-Nim 加计数。 首先怎么转化成 Staircase-Nim 呢,可以把每个金币右边到下一个金币中间那些空的地方看成这个金币的石子,那么每次金币的向左移动就是把石子从右边金币的堆移到左边…

专题网站建设策划方案浙江省住房和城乡建设厅官方网站

1.IDEA概述 IDEA全称InelliJ IDEA,是用于java语言开发的集成环境,它是业界公认的目前用于Java程序开发最好的工具。 集成环境:把代码编写,编译,执行,调试扽过多种功能综合到一起的开发工具。 下载:https…

做北京会所网站哪个好商城平台

文章目录 网络拓扑安装使用代理服务器设置隐藏者设置 使用古老的ccproxy实现代理服务器,仅做实验用途,禁止做违法犯罪的事情,后果自负。 网络拓扑 均使用Windows Server 2003系统 Router 外网IP:使用NAT模式 IP DHCP自动分配或者…

Excel表设置为细框线

Sub 设置为细框线()边框类型数组 = Array(xlEdgeLeft, xlEdgeTop, xlEdgeBottom, _xlEdgeRight, xlInsideVertical, xlInsideHorizontal)遍历已使用区域的每个单元格For Each 单元格 In ActiveSheet.UsedRangeFor Each…

US$28.5 CG A11DS 3 Buttons Wire Remote Used with CGDI K2 Remote Key Programmer 5pcs/lot

CG A11DS 3 Buttons Wire Remote Used with CGDI K2 Remote Key Programmer 5pcs/lot Package includes:5pc x CG A11DS 3 Buttons Wire Remote Pictures of CG A11DS 3 Buttons Wire Remote Used with CGDI K2 Remote…

延边网站开发depawo怎样提高网站权重

作者:Pablo Samuel Castro、Marc G. Bellemare 来源:Google AI Blog,机器之心摘要:在过去几年里,强化学习研究取得了多方面的显著进展。在过去几年里,强化学习研究取得了多方面的显著进展。这些进展使得智能体能够以超…

前端学习教程-VIte整合ECharts

ECharts 是一个强大的开源数据可视化库,而 Vite 是现代前端构建工具,两者结合可以高效开发数据可视化应用。本教程实现从创建 Vite 项目到使用 ECharts 实现各种图表。 一、环境准备 1. 创建 Vite 项目 首先确保已安…

月牙河做网站公司域名对网站排名的影响

2019独角兽企业重金招聘Python工程师标准>>> 软件的一处功能用到EasyUI的表单提交,返回一串字符串,这串字符串里有一段HTML代码,正常的情况下这段HTML代码里的双引号“ 是用 \ 转义过的。在IE中没问题,但是在Firefox和…

网站开发安全管理爬取漫画数据做网站

在项目管理中,图表作为一种直观的工具,帮助项目经理更有效的规划、监控和控制项目的各个方面,以下是项目经理常用的几张图表,它们在项目管理中发挥着至关重要的作用。 1、甘特图 甘特图(Gantt Chart)是最…

const不可改变解释

不能对const定义的变量本身重新赋值,但是可以通过其他方式更换变量里面的属性或元素(仅限对象类型和数组类型)。 “不能对const定义的变量本身重新赋值”这指的是 const 创建了一个只读的绑定(read-only binding)…