- python pandas 读取数据库_Python+Pandas 获取数据库并加入DataFrame的实例
weixin_39955149
pythonpandas读取数据库
Python+Pandas获取数据库并加入DataFrame的实例实例如下所示:importpandasaspdimportsysimportimpimp.reload(sys)fromsqlalchemyimportcreate_engineimportcx_Oracledb=cx_Oracle.connect('userid','password','10.10.1.10:1521/dbins
- python导出结果_Python连接Oracle数据查询导出结果
weixin_39712821
python导出结果
python连接oracle,需用用到模块cx_oracle,可以直接pip安装,如网络不好,可下载离线后本地安装本人由于工作需要,期望便捷查询所得结果,且固定输出某个格式具体代码如下:#!coding:utf-8importcx_Oracleconn=cx_Oracle.connect('username/password@IP/连接名')cur=conn.cursor()cur.execute
- python把oracle的查询结果导出为insert语句
优游的鱼
oraclepython数据库开发语言
可以使用cx_Oracle库在Python中连接Oracle数据库并执行查询。然后,可以使用pandas库将查询结果读取为DataFrame,并使用to_sql()方法将其导出为insert语句。示例代码如下:importcx_Oracleimportpandasaspd#ConnecttoOracledatabaseconn=cx_Oracle.connect('username/passwor
- 记一次从mysql数据迁移到oralce (基于python和pandas)
qq_36532060
mysqloraclepandaspython
记一次从mysql数据迁移到oralce(基于python)前景提要具体实现创建数据库链接读取mysql数据写入orcale结语前景提要公司最近有个从mysql迁移数据到oracle的需求,于是进行了一下方案调研和分析,但作为一个之前从没接触过Oracle的人真的感到好难,但再难也难上,这篇文章主要是记录一下做这件事时遇到的坑以及分享一下最终的方案及代码。具体实现创建数据库链接其实我觉得这个算是最
- python实现从oracle数据库查询数据生成excel透视表发送outlook
niceme!
python
#-*-coding:utf-8-*-#http://pypi.cq.pegatroncorp.com/simple--trusted-hostpypi.cq.pegatroncorp.comimportchardetimportdatetimeimporttimeimportxlwtimportwin32com.clientaswin32fromwin32com.clientimportcons
- 使用Python导出Oracle数据库数据表目录
SeanData
Python数据分析pythonoracle数据目录导出
###Oracle数据库数据表目录导出###导入包importpandasaspdimportcx_Oracle###数据库信息username='xxx'password='yyy'ipaddr='100.28.60.132'port='1521'service_name='service_name'connect_string=ipaddr+":"+port+"/"+service_name#
- 非关系型数据库和关系型数据库的区别
纠结哥_Shrek
数据库nosql
非关系型数据库(NoSQL)和关系型数据库(SQL)的主要区别体现在以下几个方面:数据模型:关系型数据库(SQL):数据以表格形式存储,数据行和列组成,每个表都有固定的模式(Schema)。常见的关系型数据库有MySQL、PostgreSQL、Oracle等。非关系型数据库(NoSQL):数据没有固定的模式,存储方式更加灵活。可以是键值对、文档、列族、图等形式。常见的非关系型数据库有MongoDB
- Oracle 数据库基础入门(一):搭建数据管理基石
Aphelios380
Oracleoracle数据库linux编辑器
在当今数字化时代,数据库作为数据管理的核心工具,对于各类应用系统的开发至关重要。尤其是在Java全栈开发领域,掌握一款强大的数据库技术是必备技能。Oracle数据库以其卓越的性能、高度的可靠性和丰富的功能,在企业级应用中广泛使用。开辟新的篇章,让我们踏上Oracle数据库的学习之旅,聚焦于基础的建表、数据操作等关键知识,为后续深入学习和实际项目应用筑牢根基。一、DDL数据定义语言:构建数据库结构框
- Oracle 数据库基础入门(二):深入理解表的约束
Aphelios380
Oraclelinuxoraclesql
在Oracle数据库的学习进程中,表的约束是构建健壮、准确且高效数据库的关键要素。约束如同数据库的“规则守护者”,它通过对数据的限制,确保了数据的完整性和一致性,就如同交通规则保障道路上车辆行驶的有序性一样。对于Java全栈开发者而言,熟练掌握Oracle数据库的约束知识,无论是在数据库设计、开发还是后续的维护中,都具有举足轻重的意义。接下来,让我们一同深入探索Oracle数据库中表的约束世界。一
- Java 编程基础:开启编程世界的大门
安年CJ
JAVAjava开发语言算法
一、Java环境搭建在开始编写Java代码之前,我们需要先搭建Java开发环境。1.安装JDK(JavaDevelopmentKit)JDK是Java开发的核心工具包,它包含了编译Java源文件所需的编译器(javac)以及运行Java程序的虚拟机(JavaVirtualMachine,JVM)等工具。你可以从Oracle官方网站下载适合你操作系统的JDK版本。下载完成后,按照安装向导进行安装。安
- oracle查询DBname 和 hostname(instance)
cyong888
数据库oracledatabase
selecthost_namefromv$instance;selectnamefromv$database一个instance上有多个database。
- 【YashanDB 知识库】通过 dblink 查询 Oracle 数据时报 YAS-07301 异常
数据库运维
问题现象某客户在通过yasql查询Oracle数据时,报如下异常:SQL>select1fromdual@link_oracle;YAS-07301externalmoduletimeout,reason:yex_serverheatbeattimeout问题的风险及影响dblink功能无法正常使用问题影响的版本所有的YashanDB版本问题发生原因查看YashanDB的run.log,有如下异常
- 【YashanDB 知识库】如何排查 YMP 报错:”OCI 版本为空或 OCI 的架构和本地系统的架构不符“
数据库程序员
问题现象在迁移预检查的版本检查阶段报错:检查未通过OCI版本为空,报错的详细信息:OCI版本为空或OCI的架构与本地系统架构不符;如何排查1、查看yasdts日志,从日志报错信息得知libdrv_oracle.so少了依赖库libnsl.so.1tail-fyashan-migrate-platform/logs/dts_log/run.log2、检查是否将OCI客户端路径加入到环境变量LD_LI
- 基于oracle linux的 DBI/DBD 标准化安装文档
linux
一、安装DBIDBI(DatabaseInterface)是perl连接数据库的接口。其是perl连接数据库的最优方法,他支持包括Orcale,Sybase,mysql,db2等绝大多数的数据库,下面将简要介绍其安装方法。1.1解压tar-zxvfDBI-1.616_901.tar.gz1.2安装依赖yuminstallperl-ExtUtils-CBuilderperl-ExtUtils-Mak
- 2.1部署logstash:9600
AustinCien
ELFKelk运维
实验环境:关闭防火墙,完成java环境yum-yinstallwgetwgethttps://d6.injdk.cn/oraclejdk/8/jdk-8u341-linux-x64.rpmyumlocalinstalljdk-8u341-linux-x64.rpm-yjava-version1.安装logstashtarxflogstash-6.4.1.tar.gz-C/usr/localln-s
- 编译 Linux 4.15.11 内核并增加系统调用
Isolarae
编译Linux4.15.11内核并增加系统调用实验日期;2018年3月21日-2018年3月22日实验环境:主机:操作系统:MicrosoftWindows10.0.16299Build16299处理器:
[email protected]物理内存:8.00GB虚拟机软件:OracleVMVirtualBox5.2.6r120293虚拟机:操作系统:openSUSE201
- OCP 认证专家零基础小白
leegong23111
oracle数据库
对于零基础的学习者而言,OCP专家认证是完全可以攻克的目标,而且其价值不可估量。从学习的角度来看,它为你提供了一套系统且全面的数据库知识体系。Oracle数据库作为行业内的领军者,其技术的深度和广度足以让你深入了解数据库的原理、架构、设计、管理与优化等各个关键环节。学习过程虽然充满挑战,但就像攀爬一座高峰,每一步的艰辛都伴随着知识积累的喜悦,当你逐渐掌握这些核心技能时,你会发现自己已经拥有了进入I
- 搭建Java集成开发环境IntelliJIDEA
愿时光不负.
intellijideajava
阶段1:安装Java开发工具包(JDK)下载JDK:访问OracleJDK或者OpenJDK官方网站,下载适合你操作系统的JDK版本。通常建议下载LTS(长期支持)版本,如JDK11或JDK17。安装JDK:运行下载的安装包,并按照提示完成安装。记下安装路径,稍后需要在IntelliJIDEA中配置。配置环境变量(Windows用户):右键点击“此电脑”>“属性”>“高级系统设置”>“环境变量”。
- python 生成excel
scan724
#!/usr/bin/envpython#-*-coding:utf-8-*-importMySQLdbfromdatetimeimportdatetimeimportcx_Oracleimportosimportxlwtimportsysreload(sys)sys.setdefaultencoding('utf-8')os.environ['NLS_LANG']='SIMPLIFIEDCHIN
- Oracle 高可用性与数据保护
鱼弦
人工智能时代oracle数据库
Oracle高可用性与数据保护介绍Oracle提供了一系列高可用性和数据保护技术,以确保数据库系统在各种故障情况下继续运行,并保护数据免受损坏或丢失。这些技术包括集群与实时应用集群(RAC)、数据卫士(DataGuard)和闪回技术。集群与实时应用集群(RAC)基本概念RAC:RealApplicationClusters允许多个服务器同时访问一组Oracle数据库实例。通过这种方式,RAC提供了
- 的卢导表:批量导入Excel文件到MySQL数据库的自动化工具
如意机反光镜裸
数据库excelmysqlexcel自动化
的卢导表:批量导入Excel文件到MySQL数据库的自动化工具简介的卢导表是一个可以批量导入excel到mysql数据库的自动化工具。支持将xls/xlsx/xlsm/xlsb/csv/txt/xml格式的Excel文件导入到mysql/oracle/sqlserver/postgresql等多种原生及国产数据库。自动化是其最大的特点,因为它可以根据excel自动生成表信息与数据库建立联系,最终将
- oracle:SID匹配错误
iteye_11495
数据库java网络
报错:java.sql.SQLException:Listenerrefusedtheconnectionwiththefollowingerror:ORA-12505,TNS:listenerdoesnotcurrentlyknowofSIDgiveninconnectdescriptorTheConnectiondescriptorusedbytheclientwas:localhost:15
- 本地Oracle数据库复制数据到Apache Hive的Linux服务器集群的分步流程
weixin_30777913
数据库大数据hive
我们已经有安装ApacheHive的Linux服务器集群,它可以连接到一个OracleRDS数据库,需要在该Linux服务器上安装配置sqoop,然后将OracleRDS数据库中所有的表数据复制到Hive。为了将本地Oracle数据库中的所有表数据复制到ApacheHiveLinux服务器集群中,您可以遵循以下详细步骤:第一步:安装和配置Sqoop1.下载并安装Sqoop您可以从ApacheSqo
- GaussDB 数据库迁移方案设计与实践
如清风一般
gaussdb数据库
一、引言随着企业数字化转型加速,数据库迁移成为IT基础设施升级的关键环节。GaussDB(华为云分布式关系型数据库)凭借其高吞吐、强一致性、弹性扩展等特性,成为政企客户替换传统数据库(如MySQL、Oracle)或升级原有GaussDB集群的首选目标。本文从技术角度系统化阐述GaussDB迁移的典型场景、核心方案及优化策略。二、迁移场景分类与技术挑战同构迁移(GaussDB→GaussDB)典型需
- Oracle数据库分区自动删除
deadknight9
Oracle运维数据库
说明:该存储过程部署后,设置成定时任务,每天执行。每次执行删除partition_position='2'的分区,删除之后,partition_position='3'的分区会前移到partition_position为'2';CREATEORREPLACEPROCEDUREBILL_CENT_JILI.DAY_PARTITIONASv_p_namevarchar2(2000);v_p_numnu
- Oracle体系结构:数据泵初探
姜豆豆耶
#Oracle体系结构oracledba数据库
数据泵是基于服务器的工具,用于数据和元数据的高速移动。可以跨数据库版本(Oracle版本)进行数据的导入导出。所以也常被用来当作数据迁移的方案之一。它有expdp、impdp两种程序进行导出和导入,下文也会进行详细介绍;但文章标题毕竟只是数据泵初探,也不会详细到让人拍手叫好的程度哈哈。那么话不多说,❀周末时间宝贵❀,开始介绍,先看目录!目录expdp例子常用参数可用关键参数交互模式命令impdp例
- Oracle 数据泵迁移步骤规范
deadknight9
运维Oracleoracle数据库
1、调研模块1.1、确认迁移用户以全库迁移为标准,也可直接通过需求方获取需要迁移的用户1)确认数据库中所有用户及其创建时间altersessionsetnls_date_format='yyyy-mm-dd-hh24:mi:ss';selectusername,createdfromdba_usersorderby2;2)以系统用户创建时间为限确认需要的用户selectusername,creat
- 华纳云:数据库的内存分配策略对性能和稳定性的影响
数据库
数据库的内存分配策略对性能和稳定性至关重要。以下是针对不同数据库(如MySQL和Oracle)的内存分配建议和最佳实践:一、MySQL数据库内存分配建议InnoDB缓冲池(BufferPool)配置建议:innodb_buffer_pool_size是MySQL中最重要的内存配置参数,建议设置为系统物理内存的60%80%。iniinnodb_buffer_pool_size=70%示例:16GB内
- ERP系统之比较——SAP Oracle BAAN JDE SSA
又是两个大汉堡
ERP系统之比较——SAP、Oracle、BAAN、JDE、SSAERP/MRPII系统剖析SAPSAP公司简介R/2和R/3系统是德国SAP公司所提供的MRPII产品。R/2是用于集中式大型机环境的系统,R/3是用于分布式的客户机/服务器环境的系统。SAP是国际上著名的标准应用软件公司。SAP总部设在德国南部的沃尔道夫市,公司成立于1972年,1988年成为德国股票上市公司。到1995年底,SA
- MongoDB 和 PostgreSQL 性能比较
AI天才研究院
Python实战DeepSeekR1&大数据AI人工智能大模型Java实战大数据人工智能语言模型JavaPython架构设计
作者:禅与计算机程序设计艺术1.简介随着互联网应用的普及,数据量越来越大,处理数据的需求也越来越强烈。数据量的爆炸性增长促使各种数据库系统应运而生。目前,基于关系型数据库管理系统(RDBMS)的产品如Oracle、MySQL等已经成为最主要的选择,但在实际生产环境中,存在性能问题,如读写延迟过高、查询效率低下、索引失效等。另外,NoSQL数据库系统如MongoDB、Cassandra等发展得相对较
- ASM系列四 利用Method 组件动态注入方法逻辑
lijingyao8206
字节码技术jvmAOP动态代理ASM
这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以
- java编程思想 --内部类
百合不是茶
java内部类匿名内部类
内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅
1,内部类的创建 内部类是创建在类中的
package com.wj.InsideClass;
/*
* 内部类的创建
*/
public class CreateInsideClass {
public CreateInsideClass(
- web.xml报错
crabdave
web.xml
web.xml报错
The content of element type "web-app" must match "(icon?,display-
name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s
- 泛型类的自定义
麦田的设计者
javaandroid泛型
为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。
采用泛型类,完成扩展。
例如有一个学生类
Student{
Student(){
System.out.println("I'm a student.....");
}
}
有一个老师类
- CSS清除浮动的4中方法
IT独行者
JavaScriptUIcss
清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。
1、结尾处加空div标签 clear:both 1 2 3 4
.div
1
{
background
:
#000080
;
border
:
1px
s
- Cygwin使用windows的jdk 配置方法
_wy_
jdkwindowscygwin
1.[vim /etc/profile]
JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43" (windows下jdk路径为D:\Java\jdk1.6.0_43)
PATH="$JAVA_HOME/bin:${PATH}"
CLAS
- linux下安装maven
无量
mavenlinux安装
Linux下安装maven(转) 1.首先到Maven官网
下载安装文件,目前最新版本为3.0.3,下载文件为
apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令;
2.进入下载文件夹,找到下载的文件,运行如下命令解压
tar -xvf apache-maven-2.2.1-bin.tar.gz
解压后的文件夹
- tomcat的https 配置,syslog-ng配置
aichenglong
tomcathttp跳转到httpssyslong-ng配置syslog配置
1) tomcat配置https,以及http自动跳转到https的配置
1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)
keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit
- 关于领号活动总结
alafqq
活动
关于某彩票活动的总结
具体需求,每个用户进活动页面,领取一个号码,1000中的一个;
活动要求
1,随机性,一定要有随机性;
2,最少中奖概率,如果注数为3200注,则最多中4注
3,效率问题,(不能每个人来都产生一个随机数,这样效率不高);
4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库)
解决方案
1,事先产生随机数1000个,并打
- java数据结构 冒泡排序的遍历与排序
百合不是茶
java
java的冒泡排序是一种简单的排序规则
冒泡排序的原理:
比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;
针对所有的元素重复以上的步骤,除了最后一个
例题;将int array[]
- JS检查输入框输入的是否是数字的一种校验方法
bijian1013
js
如下是JS检查输入框输入的是否是数字的一种校验方法:
<form method=post target="_blank">
数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br>
</form>
- Test注解的两个属性:expected和timeout
bijian1013
javaJUnitexpectedtimeout
JUnit4:Test文档中的解释:
The Test annotation supports two optional parameters.
The first, expected, declares that a test method should throw an exception.
If it doesn't throw an exception or if it
- [Gson二]继承关系的POJO的反序列化
bit1129
POJO
父类
package inheritance.test2;
import java.util.Map;
public class Model {
private String field1;
private String field2;
private Map<String, String> infoMap
- 【Spark八十四】Spark零碎知识点记录
bit1129
spark
1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的
ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中
- WAS各种脚本作用大全
ronin47
WAS 脚本
http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html
无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下
获取下载
这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自
- java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句
bylijinnan
switch
借鉴网上的思路,用java实现:
public class NoIfWhile {
/**
* @param args
*
* find x=1+2+3+....n
*/
public static void main(String[] args) {
int n=10;
int re=find(n);
System.o
- Netty源码学习-ObjectEncoder和ObjectDecoder
bylijinnan
javanetty
Netty中传递对象的思路很直观:
Netty中数据的传递是基于ChannelBuffer(也就是byte[]);
那把对象序列化为字节流,就可以在Netty中传递对象了
相应的从ChannelBuffer恢复对象,就是反序列化的过程
Netty已经封装好ObjectEncoder和ObjectDecoder
先看ObjectEncoder
ObjectEncoder是往外发送
- spring 定时任务中cronExpression表达式含义
chicony
cronExpression
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 &nb
- Nutz配置Jndi
ctrain
JNDI
1、使用JNDI获取指定资源:
var ioc = {
dao : {
type :"org.nutz.dao.impl.NutDao",
args : [ {jndi :"jdbc/dataSource"} ]
}
}
以上方法,仅需要在容器中配置好数据源,注入到NutDao即可.
- 解决 /bin/sh^M: bad interpreter: No such file or directory
daizj
shell
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具
- [转]for 循环为何可恨?
dcj3sjt126com
程序员读书
Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。
不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju
- Android实用小技巧
dcj3sjt126com
android
1、去掉所有Activity界面的标题栏
修改AndroidManifest.xml 在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"
2、去掉所有Activity界面的TitleBar 和StatusBar
修改AndroidManifes
- Oracle 复习笔记之序列
eksliang
Oracle 序列sequenceOracle sequence
转载请出自出处:http://eksliang.iteye.com/blog/2098859
1.序列的作用
序列是用于生成唯一、连续序号的对象
一般用序列来充当数据库表的主键值
2.创建序列语法如下:
create sequence s_emp
start with 1 --开始值
increment by 1 --増长值
maxval
- 有“品”的程序员
gongmeitao
工作
完美程序员的10种品质
完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的
完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:
1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强
(范围:用简单方式解决复杂问题)
- 使用KeleyiSQLHelper类进行分页查询
hvt
sql.netC#asp.nethovertree
本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D
- SVG 教程 (三)圆形,椭圆,直线
天梯梦
svg
SVG <circle> SVG 圆形 - <circle>
<circle> 标签可用来创建一个圆:
下面是SVG代码:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<circle cx="100" c
- 链表栈
luyulong
java数据结构
public class Node {
private Object object;
private Node next;
public Node() {
this.next = null;
this.object = null;
}
public Object getObject() {
return object;
}
public
- 基础数据结构和算法十:2-3 search tree
sunwinner
Algorithm2-3 search tree
Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga
- spring配置定时任务
stunizhengjia
springtimer
最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:
//------------------------定时任务调用的方法------------------------------
/**
* 存储过程定时器
*/
publi
- ITeye 8月技术图书有奖试读获奖名单公布
ITeye管理员
活动
ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
8月试读活动回顾:
http://webmaster.iteye.com/blog/2102830
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《跨终端Web》
gleams:http