python智能合约编程_如何用Python Flask开发以太坊智能合约

2023-11-11

将数据存储在数据库中是任何软件应用程序不可或缺的一部分。无论如何控制该数据库都有一个该数据的主控。区块链技术将数据存储到区块链网络内的区块中。因此,只要某个节点与网络同步,它们就会获得区块中数据的副本。因此,该技术中没有特定的数据主控。

在本教程中,我们将编写一份智能合约(我将进一步解释),以便在区块链上保留用户数据。我们将使用python web3(web3的python库)来开发和部署智能合约。一旦我们在区块链上部署了智能合约。我们将使用flask API与智能合约进行交互以存储一些数据/信息。我们将它存储在区块链上,它是不可变的。

环境要求

Python 3.6

安装

1.创建一个python虚拟环境。

Virtualenv将你的Python软件包本地化保存在你项目的虚拟环境中,而不是强迫你在系统范围内安装软件包。

$ virtualenv -p /usr/bin/python3.6 venv

$ source venv/bin/activate

2.现在我们需要Ganache那样的以太坊测试链。

Ganache是以太坊开发的个人区块链,可用于部署合约,开发应用程序和运行测试。

$ npm install -g ganache-cli

3.安装python web3

Web3.py是一个用于与以太坊交互的python库。它的API源自Web3.js Javascript API,对于使用过web3.js的人来说应该很熟悉。

$ pip3 install web3

4.Flask

Flask是一个python轻量级框架。

$ pip3 install flask

5.Flask Restful

Flask-RESTful是Flask的扩展,增加了对快速构建REST API的支持。

$ pip3 install flask-restful

Flask Marshmallow

Flask marshmallow是一个对象序列化/反序列化库。

$ pip3 install flask-marshmallow

启动以太坊测试区块链服务器

要部署智能合约,我们应该启动测试以太坊服务器。我们正在使用ganache进行测试。在终端中键入以下命令:

$ ganache-cli

image

Ganache为我们提供了10个默认测试帐户,每个帐户中有100个假ether,用于交易。我们将使用这些帐户在合约中部署和设置各种值。

image

我们可以看到gas价格和限制以及部署ganache的host:port。我们在部署合约时需要这个。

创建user.sol文件

现在我们将用Solidity编写智能合约。Solidity是在ethereum上编写智能合约的语言。智能合约包括我们将在区块链上存储的数据,数据和getter方法的可选验证函数,访问数据的setter方法。

例如,要在区块链上进行考勤注册,你将拥有一组用户对象。它将可以访问用户的getter,setter方法。由于每个用户每天只能标记一次出勤,因此你需要一个验证功能来检查,智能合约与我们通常用其他任何语言开发的应用程序非常相似。

在下面的文件中,我们使用getter,setter函数构建简单的用户合约。

1.在.sol文件中声明solidity编译器版本。

pragma solidity ^ 0.4.21;

了解使用的编译器版本。

$ solidity — version

2.导入库文件Import library。我们应该将库用于常用的实用程序函数。库可以只编译一次并反复使用(点击这里获取一些好的库资源)。

import“stringUtils.sol”;

3.为用户声明合约

contract userRecords {}

4.现在,对于基本演示,我们将存储有关用户的名称和性别信息。因此,使用struct和enum数据类型初始化这两个变量。

//枚举类型变量来存储用户性别

enum genderType { male, female }

//我们将存储在以太坊合约中的实际用户对象

struct user{

string name; genderType gender;

}

5.现在我们将声明user(struct)类型的用户对象。也可以将其声明为public,以便从合约外部访问它(有关可见范围,请单击此处)。

user user_obj;

6.现在为用户对象添加getter,setter方法。我们将在区块链上保留每个用户的信息。我们应该始终公开此方法,因为我们将从合约外部访问它们。

//设置用户公共功能

//这类似于db中的持久对象。

function setUser(string name, string gender) public {

genderType gender_type = getGenderFromString(gender);

user_obj = user({name:name, gender: gender_type});

}

//获取用户公共功能

//这类似于从db获取对象。

function getUser() public returns (string, string) {

return (user_obj.name, getGenderToString(user_obj.gender));

}

7.请注意,我们使用了两个内部函数getGenderFromString()和getGenderToString()。让我们添加这个内部函数。将它们声明为内部,因为我们不会在外面使用它们。

//用于从string中转换genderType枚举的内部函数

function getGenderFromString(string gender) internal returns(genderType) {

if(StringUtils.equal(gender, "male")) {

return genderType.male;

} else {

return genderType.female;

}

}

//将genderType枚举转换为字符串的内部函数

(string) {

if(gender == genderType.male) {

return "male";

} else {

return "female";

}

}

我们正在使用stringUtils.equal()库函数。由于此版本的solidity不支持使用(==)进行字符串比较。

8.现在我们的user.sol文件合约如下所示:

pragma solidity ^0.4.21;

// import library file

import "stringUtils.sol";

contract userRecords {

// enum type variable to store user gender

enum genderType { male, female };

// Actual user object which we will store

struct user{

string name;

genderType gender;

}

// user object

user user_obj;

//Internal function to conver genderType enum from string

function getGenderFromString(string gender) internal returns (genderType) {

if(StringUtils.equal(gender, "male")) {

return genderType.male;

} else {

return genderType.female;

}

}

//Internal function to convert genderType enum to string

function getGenderToString(genderType gender) internal returns (string) {

if(gender == genderType.male) {

return "male";

} else {

return "female";

}

}

// set user public function

// This is similar to persisting object in db.

function setUser(string name, string gender) public {

genderType gender_type = getGenderFromString(gender);

user_obj = user({name:name, gender: gender_type});

}

// get user public function

// This is similar to getting object from db.

function getUser() public returns (string, string) {

return (user_obj.name, getGenderToString(user_obj.gender));

}

}

使用python脚本编译和部署solidity文件。

1.在下面的python脚本中,我们需要实例化python-web3测试以太坊节点。我们将设置ganche url为测试以太坊节点。我们将使用下面的w3对象来部署合约。

from web3 import Web3

# web3.py instance

w3 = Web3(Web3.HTTPProvider("http://127.0.0.1:8545"))

2.现在我们将编译solidity代码。为了编译solidity代码,我们使用py-solc,它是用于solidity编译器的python扩展。

from solc import compile_files

# 编译所有合约文件

contracts = compile_files(['user.sol', 'stringUtils.sol'])

# 单独的主文件和链接文件

main_contract = contracts.pop("user.sol:userRecords")

library_link = contracts.pop("stringUtils.sol:StringUtils")

3.每当使用import语句编译.sol文件时。我们还需要链接导入文件的部署地址以及主合约。 因此,对于部署所有链接首先通过编译它(如果已经部署然后保存地址)请参见下图主合约的bin。

image

当你编译主合约时,如果你看到它的bin部分,你将找到我们正在导入的库的_stringUtils.sol:StringUtils ___________(它也可以用于合约)。 这部分我们应该通过在部署合约之前的库地址来替换它。

4.然后我们将库地址与主合约相关联。

from solc import link_code

def deploy_contract(contract_interface):

#实例化和部署合约

contract = w3.eth.contract(

abi=contract_interface['abi'],

bytecode=contract_interface['bin']

)

#从已部署的合约中获取交易哈希

tx_hash = contract.deploy(

transaction={'from': w3.eth.accounts[1]}

)

#获取tx收据以获取合约地址

tx_receipt = w3.eth.getTransactionReceipt(tx_hash)

return tx_receipt['contractAddress']

library_address = {

"stringUtils.sol:StringUtils": deploy_contract(library_link)

}

main_contract['bin'] = link_code(

main_contract['bin'], library_address

)

链接后主合约bin的见下图:

image

你将看到导入库的bin已添加。

5.现在使用我们的w3对象部署主合约。使用ethereum account {'from':w3.eth.accounts [1]}的默认地址进行部署。

def deploy_contract(contract_interface):

# 实例化和部署合约

contract = w3.eth.contract(

abi=contract_interface['abi'],

bytecode=contract_interface['bin']

)

# 从部署的合约中获取交易哈希

tx_hash = contract.deploy(

transaction={'from': w3.eth.accounts[1]}

)

# 获取tx收据以获取合同地址

tx_receipt = w3.eth.getTransactionReceipt(tx_hash)

return tx_receipt['contractAddress']

contract_address = deploy_contract(main_contract)

你将在运行ganache测试服务器的选项卡中看到以下这行:

image

这与合约部署后在tx_receipt中获得的信息相同。

6.现在将abi和contract_address存储在json文件中。这样我们以后可以在flask api中使用它来存储合约中的用户对象。

# 在json文件中添加abi(应用程序二进制接口)和交易收据

with open('data.json', 'w') as outfile:

data = {

"abi": main_contract['abi'],

"contract_address": deploy_contract(main_contract)

}

json.dump(data, outfile, indent=4, sort_keys=True)

7.现在我们的完整脚本如下所示:

import json

from web3 import Web3

from solc import compile_files, link_code, compile_source

# web3.py instance

w3 = Web3(Web3.HTTPProvider("http://127.0.0.1:8545"))

def deploy_contract(contract_interface):

# Instantiate and deploy contract

contract = w3.eth.contract(

abi=contract_interface['abi'],

bytecode=contract_interface['bin']

)

# Get transaction hash from deployed contract

tx_hash =contract.deploy(transaction{'from':w3.eth.accounts[1]})

# Get tx receipt to get contract address

tx_receipt = w3.eth.getTransactionReceipt(tx_hash)

return tx_receipt['contractAddress']

# compile all contract files

contracts = compile_files(['user.sol', 'stringUtils.sol'])

# separate main file and link file

main_contract = contracts.pop("user.sol:userRecords")

library_link = contracts.pop("stringUtils.sol:StringUtils")

# print bin part in console you will see 'stringUtils' in that we need to link library address in that bin code.

# to that we have to deploy library code first then link it

library_address = {

"stringUtils.sol:StringUtils": deploy_contract(library_link)

}

main_contract['bin'] = link_code(

main_contract['bin'], library_address)

# add abi(application binary interface) and transaction reciept in json file

with open('data.json', 'w') as outfile:

data = {

"abi": main_contract['abi'],

"contract_address": deploy_contract(main_contract)

}

json.dump(data, outfile, indent=4, sort_keys=True)

创建flask api以为用户存储不同的值

你只需部署一次合约。但是使用它的地址,你会一次又一次地存储数据。同样,在db的世界中,你只需定义一次模型/模式,但你将在db中添加不同的行/文档。

我们将使用flask post api来获取用户的用户信息并返回成功。

from flask import Flask, Response, request, jsonify

from marshmallow import Schema, fields, ValidationError

def check_gender(data):

valid_list = ["male", "female"]

if data not in valid_list:

raise ValidationError(

'Invalid gender. Valid choices are'+ valid_list

)

#For api validations

class UserSchema(Schema):

name = fields.String(required=True)

gender = fields.String(required=True, validate=check_gender)

# Initializing flask app

app = Flask(__name__)

# api to set new user every api call

@app.route("/blockchain/user", methods=['POST'])

def user():

body = request.get_json()

result, error = UserSchema().load(body)

if error:

return jsonify(error), 422

return jsonify({"data": result}), 200

由于这不是flask教程,我不会详细说明这一点,如果flask不熟悉可以看这个flask教程学习下。我们的API用户将从客户端获取数据(curl请求)并对其进行验证将其返回给客户端(curl请求)

2.现在我们将初始化web3对象以与已部署的用户合约进行通信。

from web3 import Web3

# web3.py instance

w3 = Web3(Web3.HTTPProvider("http://127.0.0.1:8545"))

3.现在我们将获得之前存储在data.json文件中的abi和合约地址。

with open("data.json", 'r') as f:

datastore = json.load(f)

abi = datastore["abi"]

contract_address = datastore["contract_address"]

4.选择交易的默认帐户地址。每次在合约中为用户设置新值。你会从钱包里拿出一些gas。

w3.eth.defaultAccount = w3.eth.accounts[1]

5.最后,你将在以太坊合约中设置api调用用户对象时获得的值。

@app.route("/blockchain/user", methods=['POST'])

def user():

# Create the contract instance with the newly-deployed address

user = w3.eth.contract(address=contract_address, abi=abi)

body = request.get_json()

result, error = UserSchema().load(body)

if error:

return jsonify(error), 422

tx_hash = user.functions.setUser(

result['name'],result['gender']

)

tx_hash = tx_hash.transact()

# Wait for transaction to be mined...

w3.eth.waitForTransactionReceipt(tx_hash)

user_data = user.functions.getUser().call()

return jsonify({"data": user_data}), 200

我们首先使用abi和contract_address获得部署合约。

user = w3.eth.contract(address=contract_address, abi=abi)

然后我们可以使用合约实例调用任何合约公共函数。在为用户设置值之后,我们将使用transact方法将其公之于众。这将在以太坊区块中添加新的用户值。

tx_hash = user.functions.setUser(

result['name'],result['gender']

).transact()

现在我们可以使用call方法获得已在合约中设置的值,这将调用合约函数而不在区块链中添加任何区块。

user_data = user.functions.getUser().call()

我们的api文件的最终代码如下所示。将其另存为app.py。

import json

from flask import Flask, Response, request, jsonify

from marshmallow import Schema, fields, ValidationError

from web3 import Web3

# web3.py instance

w3 = Web3(Web3.HTTPProvider("http://127.0.0.1:8545"))

w3.eth.defaultAccount = w3.eth.accounts[1]

# Get stored abi and contract_address

with open("data.json", 'r') as f:

datastore = json.load(f)

abi = datastore["abi"]

contract_address = datastore["contract_address"]

def check_gender(data):

valid_list = ["male", "female"]

if data not in valid_list:

raise ValidationError(

'Invalid gender. Valid choices are'+ valid_list

)

#For api validations

class UserSchema(Schema):

name = fields.String(required=True)

gender = fields.String(required=True, validate=check_gender)

# Initializing flask app

app = Flask(__name__)

# api to set new user every api call

@app.route("/blockchain/user", methods=['POST'])

def user():

# Create the contract instance with the newly-deployed address

user = w3.eth.contract(address=contract_address, abi=abi)

body = request.get_json()

result, error = UserSchema().load(body)

if error:

return jsonify(error), 422

tx_hash = user.functions.setUser(

result['name'],result['gender']

).transact()

# Wait for transaction to be mined...

receipt = w3.eth.waitForTransactionReceipt(tx_hash)

user_data = user.functions.getUser().call()

return jsonify({"data": user_data}), 200

运行以下命令以启动服务器。

$ FLASK_APP=app.py flask run

用curl调用api

$ curl -H "Content-Type: application/json" --request POST -d '{"name":"John Doe","gender":"male"}' http://localhost:5000/blockchain/user

你也可以在这里找到完整代码。

python用web3.py库开发以太坊来说非常的方便,有兴趣的用户可以关注我们的python以太坊教程,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。

另外其他语言可以学习的以太坊教程如下:

web3j教程,主要是针对java和android程序员进行区块链以太坊开发的web3j详解。

以太坊教程,主要介绍智能合约与dapp应用开发,适合入门。

以太坊开发,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。

php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和事件等内容。

C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和事件等。

汇智网原创翻译,转载请标明出处。这里是原文

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

python智能合约编程_如何用Python Flask开发以太坊智能合约 的相关文章

  • React---使用componentDidUpdate钩子函数判断路由地址是否发生变化

    在组件更新 例如组件的路由更新 后会执行componentDidUpdate钩子函数 componentDidUpdate方法会传入两个参数 prevProps prevState prevProps prevState可以拿到组件更新前的
  • Web3 入门手册:从认知到实践

    如果你也喜欢 Web3 希望在这做些有趣的 有意义的事情 那么我希望这篇文章可以帮助到你 送给想要进入 Web3 或者刚刚进入 Web3 的小伙伴 但是考虑到两点原因 我还是打算把这件事推迟一些时日 一是在各大媒体都鼓吹 All In We
  • 如何将pdf转换成txt?悄悄告诉你3个好用的转换方法

    pdf和txt文档都是我们经常会使用到的文档格式 这两种文档各有各的特点 pdf文档适合用于展示 而txt文档适合用于整理各种文字信息 在面对不同的情况时我们就要使用不同的文档 就比如将纯文字的资料进行搜集的时候 利用txt文档会更方便 而
  • 如何在vue中引入字体

    一 为什么要引入字体 在前端开发中 选用合适的字体往往会极大地提升网站的视觉体验 然而 网页中默认字体的种类和风格有限 且在不同的设备 浏览器上渲染效果不尽相同 因此 很多开发者会选择自定义字体来提升用户体验 二 如何引入字体 1 搜索下载
  • 2020华为杯数学建模总结

    2020研究生数学建模竞赛总结 题目 2020年中国研究生数学建模竞赛B题 降低汽油精制过程中的辛烷值损失模型 一 背景 汽油是小型车辆的主要燃料 汽油燃烧产生的尾气排放对大气环境有重要影响 为此 世界各国都制定了日益严格的汽油质量标准 见
  • linux 套接字文件类型,Linux下的文件类型

    Linux下的文件类型 1 开头 表示普通文件 2 d开头 表示目录文件 3 b开头 表示块设备 4 c开头 表示是字符设备 5 I开头 表示符号链接文件 6 p开头 表示管道文件pipe 7 s开头 表示套接字文件socket root
  • 浅谈BERT/Transformer模型的压缩与优化加速

    作者 姚益武 单位 阿里巴巴集团 研究方向 AI算法与工程架构 前言 BERT Transformer 结构及其变体 已成为自然语言处理 NLP 语音识别 ASR 等领域的主流序列建模结构 并且 相比于卷积操作的局部特征提取能力 以及平移不
  • 【Python】ValueError: The truth value of a Series is ambiguous. Use a.empty, a.bool(), a.item(), a.any

    一 问题描述 在使用Python的判断语句的时候 data2 data2 Month 11 and data2 Day 11 我的本意是想找出11月11日的数据 运用上面的代码 却得到了报错 报错信息 ValueError The trut
  • [QT编程系列-38]:数据存储 - SQLite数据库存储与操作

    目录 1 SQLite数据库概述 1 1 简介 1 2 SQLite不支持网络连接 1 3 SQLite不需要安装MySQL Server数据库 1 4 SQLite性能 1 5 SQLite支持的数据条目 2 SQLite操作示例 3 Q
  • 找不到插件 ‘org.springframework.boot:spring-boot-maven-plugin:‘问题

    出现pom文件找不到插件 org springframework boot spring boot maven plugin 问题 可能是因为版本没有绑定好 去一级父类依赖找对应的插件版本 在pom文件中加上 把父类的version加到po
  • 1小时学会CSS-下

    今天给大家分享的内容包含CSS 盒子模型 CSS 标准布局 CSS 浮动布局 并以案列进行详细说明 一 CSS 盒子模型 CSS 将所有元素都当成盒子 CSS布局其实就是如何堆放盒子 组成 content 内容 gt padding 内边距
  • 【c语言】小程序游戏——飞机游戏(二)

    在接下来 我们需要对飞机添加一些属性 1 利用键盘控制飞机的移动 2 按空格键可以发射激光 NO 1 利用键盘控制飞机的移动 首先我们需要了解的是 如果想要通过按键来控制飞机的移动 那么我们具体要怎么控制呢
  • Verilog(4)系统任务monitor,time,stop,random等,编译预处理语句

    调试用系统任务和常用编译预处理语句 用于调试和差错的系统任务 以及编写模块时的预处理语句 系统任务 monitor 提供了监控和输出参数列表中表达式或变量值的功能 参数列表中输出控制格式字符串和输出表列的规则和 d i s p l a
  • java基础之replace,replaceAll

    走在乡间的小路上 回首过往 以下代码结果都是显示在Console框中 所以 n会被解析成换行 n只显示 n 所以看到结果换行其实是输出了 n 看到输出 n 其实输出的是 n replace和replaceAll是编程中经常用到的替换函数 成
  • 求出1~N范围中所有的素数

    判断是否为素数 public static boolean isPrime int n int sqrt int Math sqrt n int i for i 2 i lt sqrt i if n i 0 break if i gt sq
  • 小程序瀑布流布局

    list wxml列表
  • Java的深浅拷贝机制

    Java的深浅拷贝机制 我们先理解一下深浅拷贝的概念 1 浅拷贝 Java在进行对象拷贝的过程中 对于他的成员变量进行拷贝 如果是基本数据类型 就会直接拷贝他的值 如果是引用类型 则会拷贝他的引用地址 而不会拷贝对象本身 2 深拷贝 Jav
  • Windows 10 和 Windows 11 有什么区别?

    Windows 10 和 Windows 11 有什么区别 Windows 11 具有 Windows 10 的全部功能和安全性 同时具有经重新设计而焕然一新的外观 它还自带一些新的工具 声音和应用 所有细节面面俱到 颜值 功能与安全性集于
  • Python字符串转为字典方法大全

    方法一 通过内置函数eval 1 2 3 4 5 6 7 8 9 10 11 12 13 str info name test age 18 dict info eval str info print string info type is

随机推荐

  • 【MYSQL】第一篇 Mysql如何处理百万级别的数据

    1 应尽量避免在 where子句中使用 或 lt gt 操作符 否则将引擎放弃使用索引而进行全表扫描 2 应尽量避免在 where子句中对字段进行 null值判断 否则将导致引擎放弃使用索引而进行全表扫描 3 尽量避免在 where子句中使
  • Jmeter性能测试 —— TPS拐点寻找

    寻找TPS性能拐点1 准备脚本 在本地电脑调试Jmeter压测脚本 上传到压测机Jmeter所在的服务器 2 执行压力测试 执行压测脚本 jmeter n t xianchengzuse jmx 记录业务压测数据 3 监控服务器性能指标 监
  • MySQL____高级查询、联合查询

    文章目录 一 聚合查询 1 count查询 总数统计 1 1count 用法1 1 2 count 用法2 1 3count 用法3 1 4 注意事项 2 SUM函数 总和统计 3 AVG函数 4 MAX函数 5 MIN函数 二 ifnul
  • 如何统计iOS产品不同渠道的下载量?

    一 前言 在开发过程中 Android可能会打出来很多的包 用于标识不同的商店下载量 原来觉得苹果只有一个商店 AppStore 如何做出不同来源的统计呢 本篇文章就是告诉大家如何做不同渠道来源统计 二 正文 先看一下苹果自家统计到的数据
  • unity局域网开关机步骤一-网络唤醒-设置电脑使允许局域网内其他电脑控制

    被控制端主机的设置 一 Bois界面网络唤醒的设置 外链图片转存失败 源站可能有防盗链机制 建议将图片保存下来直接上传 img TR2xwyAx 1593577482582 htts img blog csdnimg cn 20200701
  • 详细及易读懂的 大津法(OTSU)原理 和 比opencv自带更快的算法实现

    OTSU算法原理简述 最大类间方差是由日本学者大津 Nobuyuki Otsu 于1979年提出 是一种自适应的阈值确定方法 算法假设图像像素能够根据阈值 被分成背景 background 和目标 objects 两部分 然后 计算该最佳阈
  • C++之拷贝构造、拷贝赋值

    拷贝构造 class Stu public int no string name int age public Stu int no 10086 string name jin int age 18 no no name name age
  • springboot+mybatis-plus+双数据源

    springboot mybaits plus mybatis plus的双数据源和逆向工程的配置整合 废话不多说直接开始干 mybatis plus逆向工程的配置 public class CodeGenerator Project pa
  • JVM、GC和常用命令

    这是11月份的一个分享 借着组内分享的机会 重新梳理了一遍JVM的一些基本概念和学习资料 在这个PPT中 关于G1的部分比较粗略 最近正在恶补G1的知识 后面可能会单独整理一篇分享出来 需要原件的 可以在我的公众号 duqi Voice 后
  • 【头歌】Linux Linux从入门到精通

    https www educoder net paths 43 第1关 Linux初体验 bin bash 在以下部分写出完成任务的命令 begin cd ls a end 第2关 Linux常用命令 bin bash 在以下部分写出完成任
  • linux ping命令参数说明及使用

    一 参数说明 在控制台输入ping会有参数说明 BusyBox v1 22 1 2019 07 23 15 07 27 CST multi call binary Usage ping OPTIONS HOST Send ICMP ECHO
  • 2018 年,关于深度学习的 10 个预测

    我有一种预感 2018年 所有的事情都会发生巨变 我们在2017年看到的深度学习取得的惊人突破将会以一种强大的方式延续到2018年 2017年在深度学习领域的研究成果将会应用于日常的软件应用中 下面是我对2018年深度学习的10个预测 1
  • 抓取chrome所有版本密码

    文章首发先知社区 https xz aliyun com t 9752 工具已上传到github https github com SD XD Catch Browser 谷歌浏览器存储密码的方式 在使用谷歌浏览器时 如果我们输入某个网站的
  • python 无头模式 绕过检测_python爬虫反反爬虫有绝技,轻松绕开百度人机验证!...

    你可能已经了解到了无头浏览器的作用以及使用的方法 那么本篇文章就让我们一起用无头浏览器做点事情 是的你没有看错 我们要 搞 的对象就是百度指数这个网站 不知道你平时是否会应用到这里面的数据呢 今天的主要目标就是使用无头浏览器登录百度指数网站
  • 离散傅里叶变换MATLAB实现

    文章目录 要求 一 连续函数抽样 二 抽样长度确定 三 DFT 1 使用一次循环实现DFT 2 使用矩阵实现DFT 总结 要求 有一单频信号y t sin 2 ft 其中f 100Hz 和f 500Hz 分别用DFT求y t 的谱 抽样频率
  • 某中学校校园网络方案设计(课程设计)

    目录 一 绪论 1 1 中小学校园信息化应用的现状 1 2 中小学校园网络系统现状 二 需求分析 2 1 获取需求的途径 方法 过程等 2 2基本情况 2 3 建筑分布 2 4 信息点 需联网的设备 分布及数量 表格 三 设计 3 1 设计
  • cesium for ue5中actor的cesium georeference组件的改变(英文教程文档是更新了的)

    今天 重新回顾下cesium for ue的教程 actor添加cesium georeference组件 发现在ue5中 没有这个组件了 忍住卸载ue5 重新安装ue4 27的冲动 cesium的组件数量增多了 反而功能减少了 不可能 绝
  • Unity之UI

    Unity之UGUI 一 Canvas 1 创建Canvas 2 Render Mode 1 Screen Space Overlay 2 Screen Space Camera 3 World Space 3 Pixel Perfect
  • 【计算机毕设项目】基于大数据的社交平台数据爬虫舆情分析可视化系统

    文章目录 0 前言 1 课题背景 2 实现效果 实现功能 可视化统计 web模块界面展示 3 LDA模型 4 情感分析方法 预处理 特征提取 特征选择 分类器选择 实验 5 部分核心代码 0 前言 这两年开始毕业设计和毕业答辩的要求和难度不
  • python智能合约编程_如何用Python Flask开发以太坊智能合约

    将数据存储在数据库中是任何软件应用程序不可或缺的一部分 无论如何控制该数据库都有一个该数据的主控 区块链技术将数据存储到区块链网络内的区块中 因此 只要某个节点与网络同步 它们就会获得区块中数据的副本 因此 该技术中没有特定的数据主控 在本