首页 文章 精选 留言 我的

精选列表

搜索[加密工具],共10000篇文章
优秀的个人博客,低调大师

工具】代码生成器-python脚本

我觉得造轮子这件事情,是谁都可以做的。只不过做得好或者不好而已,用心了做得就要优雅一点。 之前用过java的代码生成器,什么pojodobodbo都能生成,于是我也来自己造一个轮子。 造轮子的事情是没必要做得,费神费心,还没人家做得好,那么我还是要做,就当是体验一把了,看看细节是怎么实现的。 前期准备: 一台装有python、mysql的机器和若干待生成的表。 python版本:3.6.4 python安装mysql模块:pip install pymysql。(python2安装:pip install mysql-python 目标语言:java 待生成表格:为了实现各种数据类型,我们定义一个包含多种数据类型的实体表t_model,数据结构如下。 drop table if exists t_model; create table t_model( f_id varchar(64) primary key not null, --varchar 主键 f_number int null, f_datetime datetime, f_double double ) 目标格式: package com.dyi.po; import java.util.Date; /** * 表t_model模型 * @author WYB * */ public class Model { private String id; private int number; private Date date; private double dble; public Model() { super(); } public Model(String id, int number, Date date, double dble) { super(); this.id = id; this.number = number; this.date = date; this.dble = dble; } /** * * @return */ public String getId() { return id; } public void setId(String id) { this.id = id; } /** * * @return */ public int getNumber() { return number; } public void setNumber(int number) { this.number = number; } /** * * @return */ public Date getDate() { return date; } public void setDate(Date date) { this.date = date; } /** * * @return */ public double getDble() { return dble; } public void setDble(double dble) { this.dble = dble; } } 开始编写脚本 第一步:查询表结构 sql = """ select column_name,data_type,character_maximum_length,column_key,column_comment from information_schema.`COLUMNS` where TABLE_NAME = "%s" """%tableName cursor.execute(sql) tableColumnList = cursor.fetchall() 第二步:分析列的类型 cursor.execute(sql) tableColumnList = cursor.fetchall() modelName = tableName modelName = modelName[modelName.find("_") + 1:] modelName = modelName[0].upper()+modelName[1:] fieldInfoList = [] for col in tableColumnList: colName = col[0] colType = col[1].lower() colLen = col[2] priKey = col[3] comment = col[4] 第三步:拆分字段名,处理细节,生成代码 import pymysql ##连接数据库 db = pymysql.connect("localhost","root","root","stagebo") cursor = db.cursor() def log(str): print(str) def getTableList(): log("开始查询所有数据表...") cursor.execute("show tables") tableList = cursor.fetchall() tList = [] for t in tableList: tList.append(t[0]) return tList def getTableInfo(tableName): log("开始获取表结构") sql = """ select column_name,data_type,character_maximum_length,column_key,column_comment from information_schema.`COLUMNS` where TABLE_NAME = "%s" """%tableName cursor.execute(sql) tableColumnList = cursor.fetchall() modelName = tableName modelName = modelName[modelName.find("_") + 1:] modelName = modelName[0].upper()+modelName[1:] fieldInfoList = [] for col in tableColumnList: colName = col[0] colType = col[1].lower() colLen = col[2] priKey = col[3] comment = col[4] #字段去掉“f_” colName = colName[colName.find("_")+1:] #colName = colName[0].upper()+colName[1:] #判断类型 type = "" if colType in ["varchar","nvarchar"]: type = "String" elif colType == "int": type = "int" elif colType in ["double","float"]: type = "double" pk = False if priKey == "PRI": pk = True fieldInfoList.append([colName,type,pk]) file = open("%s.java"%modelName, "w") code = """ package com.dyi.po; import java.util.*; /** * 表%s模型 * */ """ %tableName code += "public class %s {"%modelName for item in fieldInfoList: code += """ private %s %s; """%(item[1],item[0]) code +=""" /* * 空构造函数 */ public %s(){ super(); } """%modelName code += """ /** *全参数构造函数 */ public %s("""%modelName for item in fieldInfoList: code += "%s %s, "%(item[1],item[0]) code = code[:-1] code += """) { super();""" for item in fieldInfoList: code += """ this.%s = %s;"""%(item[0],item[0]) code += """ }""" for item in fieldInfoList: t = item[1] n = item[0] nu = n[0].upper()+n[1:] code += """ /** * * @return */ public %s get%s(){ return this.%s; } public void set%s(%s %s){ this.%s = %s; } """%(t,nu,n,nu,t,n,n,n) code += "}" file.write(code) file.flush() file.close() if __name__ == "__main__": #查询表 tableList = getTableList() #定义要导出的表 tableToScript = ["t_model"] #开始遍历 for tableName in tableToScript: if tableName not in tableList: continue print(tableName) getTableInfo(tableName) 结果展示 package com.dyi.po; import java.util.*; /** * 表t_model模型 * */ public class Model { private String id; private int number; private date; private double dble; /* * 空构造函数 */ public Model(){ super(); } /** *全参数构造函数 */ public Model(String id, int number, date, double dble,) { super(); this.id = id; this.number = number; this.date = date; this.dble = dble; } /** * * @return */ public String getId(){ return this.id; } public void setId(String id){ this.id = id; } /** * * @return */ public int getNumber(){ return this.number; } public void setNumber(int number){ this.number = number; } /** * * @return */ public getDate(){ return this.date; } public void setDate( date){ this.date = date; } /** * * @return */ public double getDble(){ return this.dble; } public void setDble(double dble){ this.dble = dble; } } 然后流程就通了,一通百通,别的就可以照旧了~~~黑夜给了我黑色的眼睛,我却用它寻找光明

优秀的个人博客,低调大师

ITIL工具系列之CA-Unicenter

CA-Unicenter是分布式异构环境下集中自动化的ITIL软件,它的显著特点是功能丰富、界面较友好、功能比较细化。它提供了各种网络和系统管理功能,可以实现对整个网络架构的每一个细小细节(从简单的PDA到各种大型主机设备)的控制,并确保企业环境的可用性。从网络和系统管理角度来看,Unicenter可以在NT到大型主机的所有平台上;从自动运行管理方面来看,它可以实现日常业务的系统化管理,确保各主要架构组件(WEB服务器和应用服务器中间件)的性能和运转。从数据库管理来看,它还可以对业务逻辑进行管理,确保整个数据库范围的最佳服务。它提供用户管理、安全、工作进程管理、事务管理、磁盘和磁带管理、报表分发、问题追踪、数据库监控、资源计费等功能,适应的平台从PC LAN、OS/2、WindowsNT、UNIX到Mainframe。CA-Unicenter/Star可提供用户通过PC(OS/2或NT)控制UNIX其他大型主机的功能。Unicenter Service Desk率先采纳了行业最佳实践,成为自动化IT流程、提供法规遵从审计轨迹的基础。 Unicenter Service Desk在企业应用方面比较容易,使用WEB界面,可以基于AD做登录身份验证,用户直接访问提交CASE,然后CASE会指派到用户所在的LOCAL IT Group,并生成邮件通知用户和处理工程师,CASE发生变更后,用户能够得到及时通知,由于界面简洁,用户提交时输入主题和内容即可,还能添加多个附件,截图可以直接粘到CASE里,方便用户操作,适合在EXCHANGE邮件环境应用,缺点是CASE分为事件和问题两种,用户没有进行进一步分类,指派到组里每个成员都会收到大量的CASE邮件,CASE的级别有高、中、低三类,自动会按时间提升级别,HOLD之后什么时间内关闭没有限制,CASE生成二次数据的报告,只能看到CASE量和处理是否及时,难以评估IT的工作质量和业务部门真实需求解决情况。另外,由于国内代理技术限制,难以针对用户应用进一步定制,所以应用的范围和程度较小。 Unicenter网络管理主要解决两方面问题:设备管理和性能管理。它不仅可以对支持标准SNMP(简单网管协议)的设备进行直接管理,还能够对不支持SNMP协议的网络设备进行管理,极大地扩展了设备管理的范围。在采集和汇总大量原始数据的基础上,Unicenter的性能管理根据广东移动考核指标的要求自动生成直观、易懂的性能报表,通过Unicenter,来自各个系统、数据库、应用系统所产生的消息、报警等事件,将自动传送到管理员那里,而无须等待系统轮询。管理员对需要报告的事件和程度进行方便的定义和修改,以满足广东移动的具体需要,根据这些事件,管理员可以灵活地定义事件发生之后的相应措施。CA针对Unicenter的新价格模式摈弃了“power units”的报价方法,代之以分层次的定价模式,大大简化了购买和维护程序。加上此前发布的灵活的业务模式,它是业界对客户最友好的基础架构管理解决方案的授权方式。产品适用于电信运营商、IT技术服务商、金融、运输、企业、教育、政府等网管方面有大规模投入、IT管理机构健全、维护人员水平较高的用户。 Unicenter Service Desk是什么? Unicenter Service Desk是一种产品,它提供了服务请求管理、事故管理、问题管理和变更管理,最大化了分析师的生产率,增强了响应能力。Unicenter Service Desk遵从ITIL、建立在可扩展的已证实架构上,使IT流程对准业务目标,同时为员工、客户和合作伙伴提供了出色的服务。 Unicenter Service Desk面临的挑战是什么? Unicenter Service Desk简化、管理复杂的服务和支持需求,解决了一些公共挑战,如管理服务承诺、保持最终用户的生产率、使客户始终满意等。 Unicenter Service Desk具有哪些特性? Unicenter Service Desk具有的特性包括:用于事故管理、问题管理和变更管理的工作流驱动式ITIL自动控制;向最终用户提供了自我服务功能。它还管理服务级别以保证响应时间承诺和自动化客户调查,从而确保了高质量的支持。 Unicenter Service Desk支持哪些平台? Microsoft Windows、Linux (Red Hat Enterprise)、UNIX (Sun/Solaris/HP-UX/IBM-AIX)等服务器;Microsoft IE、Mozilla、Firefox等Web接口;Ingres、Microsoft SQL Server和Oracle等数据库。 本文转自 zhaiken 51CTO博客,原文链接:http://blog.51cto.com/zhaiken/508385,如需转载请自行联系原作者

优秀的个人博客,低调大师

完整的抽屉式工具实现

可能大家会遇到一个应用图标过多不好排版也不好处理的问题吧?小马学习了下一个应用图标过多时的一个简单的处理方式,就是用安卓提供的SlidingDrawer来完成漂亮的排版与功能实现,废话不多说,先上效果图再看具体代码实现: 一: 小抽屉未展开时: 二:小抽屉展开时: 三:小抽屉中功能图标过多时(这个好神奇,竟然能自己扩充,激动呀) 四:如果要实现抽屉中不同图标的不同功能时,更简单,直接给GridView的项加事件实现就可以啦,吼吼 下面我们来看下代码实现: packagecom.xiaoma.www; importandroid.app.Activity; importandroid.os.Bundle; importandroid.view.View; importandroid.widget.AdapterView; importandroid.widget.AdapterView.OnItemClickListener; importandroid.widget.GridView; importandroid.widget.ImageView; importandroid.widget.SlidingDrawer; importandroid.widget.Toast; importandroid.widget.SlidingDrawer.OnDrawerCloseListener; importandroid.widget.SlidingDrawer.OnDrawerOpenListener; /** *@Title:SlidingDrawerDemoActivity.java *@Packagecom.xiaoma.www *@Description:抽屉式控件SlidingDrawer的显示与隐藏 *@authorMZH */ publicclassSlidingDrawerDemoActivityActivityextendsActivity{ //声明 privateSlidingDrawersDrawer; privateGridViewgvGridView; //点击小抽屉的小标志哦,不然没得点呐 privateImageViewmyImage1; /** *下面这个两个资源,小马提示下,就是在定义的时候必须一一对应,比如:10:10 *如果少了任何一项的话,会报数组越界异常的,所以稍微注意下 *另外,小马的DEMO本来GridView中内容很少的,但是手闲的,试了下内容撑不下 *一个屏幕时怎么办,没想安卓那么强大,呵,自己扩充,效果图我已经贴上面咯 */ //声明所有图标资源 privateinticons[]={ R.drawable.angry_birds,R.drawable.browser,R.drawable.dropbox, R.drawable.googleearth,R.drawable.lastfm,R.drawable.xiaoma, R.drawable.xbmc,R.drawable.youtube,R.drawable.notes, R.drawable.messages_dock,R.drawable.contacts, R.drawable.facebook,R.drawable.wapedia }; //声明所有图标资源title privateStringitems[]={ "愤怒的小鸟","浏览器","dropbox","谷歌地球","AS","小马果的驴子","嘛东西", "YouTuBe","记事本","消息提示","通讯薄","面谱","WAP" }; /**Calledwhentheactivityisfirstcreated.*/ @Override publicvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.main); init(); } /** *初始化方法实现 */ privatevoidinit(){ //我的抽屉 sDrawer=(SlidingDrawer)findViewById(R.id.mySliding); //点击抽屉时的小图标 myImage1=(ImageView)findViewById(R.id.myImage1); //抽屉中要显示的内容 gvGridView=(GridView)findViewById(R.id.gridView); //初始化自定义的网格布局适配器并设置到网络布局上 GridViewAdapteradapter=newGridViewAdapter(getApplicationContext(),items,icons); gvGridView.setAdapter(adapter); gvGridView.setOnItemClickListener(newOnItemClickListener(){ @Override publicvoidonItemClick(AdapterView<?>parent,Viewview, intposition,longid){ /** *此处可以实现单击不同图标时的不同功能哦,小马就不多讲废话,简单提示下 */ Toast.makeText(getApplicationContext(), "单击了第"+position+"项",Toast.LENGTH_SHORT).show(); } }); /** *下面给我的抽屉添加两个事件监听器,大家也可以只加载一个,因为考虑到用户体验 *在点击抽屉的小标志打开抽屉时我设置一个打开的图标,关闭时设置关闭图标,这样 *比较好玩,吼吼,下面两个监听大家随意 */ //打开抽屉监听 sDrawer.setOnDrawerOpenListener(newOnDrawerOpenListener(){ @Override publicvoidonDrawerOpened(){ myImage1.setImageResource(R.drawable.close); } }); //关闭抽屉监听 sDrawer.setOnDrawerCloseListener(newOnDrawerCloseListener(){ @Override publicvoidonDrawerClosed(){ myImage1.setImageResource(R.drawable.open); } }); } } 怎么样?简单吧?吼吼,再来看下我们的抽屉主布局,里面有比较重要的两点,大家仔细看下注释: <?xmlversion="1.0"encoding="utf-8"?> <RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/background" android:orientation="vertical"> <!--android:handle指定我们点击抽屉时的小图标,这个必须指定,否则没办法点, 主要是去哪点出来?所以这个属性必须加 android:content指定我们的抽屉里面加载的布局 --> <SlidingDrawer android:id="@+id/mySliding" android:layout_width="fill_parent" android:layout_height="fill_parent" android:handle="@+id/layout1" android:content="@+id/gridView" android:orientation="horizontal" > <LinearLayout android:id="@+id/layout1" android:layout_width="35px" android:layout_height="fill_parent" android:gravity="center_vertical" > <ImageView android:id="@+id/myImage1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/open" /> </LinearLayout> <GridView android:id="@+id/gridView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:numColumns="3" android:gravity="center" /> </SlidingDrawer> </RelativeLayout> 下面再来看下我们对网格布局填充的自定义布局,很简单的,对吧,嘿嘿 <?xmlversion="1.0"encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <ImageView android:id="@+id/icon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" /> <TextView android:id="@+id/text" android:layout_width="fill_parent" android:layout_height="20sp" android:gravity="center" android:textColor="@drawable/black" /> </LinearLayout> 最后,老样子,如果小马代码写得太乱,希望看文章的你我多指正,有错必改的,吼吼,谢谢,希望多提意见给小马,这才是对小马最大的帮助,小DEMO源码小马放附件里面了,有用到的朋友可下载改改后,实现自己想要的完美功能吧,加油加油,谢谢 附件:http://down.51cto.com/data/2359704 本文转自华华世界 51CTO博客,原文链接:http://blog.51cto.com/mzh3344258/767188,如需转载请自行联系原作者

优秀的个人博客,低调大师

Linux安装 VMware tools 工具的方法

查看分区 fdisk -l /dev/sda 显示: Device Boot Start End Blocks Id System /dev/sda1 * 1 39 307200 83 Linux Partition 1 does not end on cylinder boundary. /dev/sda2 39 2358 18631680 83 Linux /dev/sda3 2358 2611 2031616 82 Linux swap / Solaris 1 2 3 4 5 6 *注意:这里使用/dev/sda1取代下面的/dev/cdrom进行安装VMware tools* 下面的部分来源地址 如下内容的来源是:http://blog.csdn.net/sz_bdqn/article/details/46778629 1)以root身份登陆计算机 2)开始安装Vmware 选择VM–>install VMware Tools 3)输入如下命令 [root@localhost ~]# mkdir /mnt/cdrom 输入 注意空格 [root@localhost ~]#mount /dev/cdrom /mnt/cdrom/ 4) [root@localhost ~]# cd /mnt/cdrom/ [root@localhost cdrom]# ls 显示其下有哪些文件,类似 windows中的dir 5)将文件拷贝至根目录下的tmp这个临时目录下 //拷贝到/tmp下这里如果VMware的版本不同出现的数字也是不同的 ,不过差不过,至于这串字符你要是怕输错了,可以复制粘贴 右击 [root@localhost cdrom]# cp VMwareTools-7.8.4-126130.tar.gz /tmp 6)进入tmp文件夹 [root@localhost cdrom]# cd /tmp/ [root@localhost tmp]# tar zxvf VMwareTools-6.5.0-118166.tar.gz //解压文件 7)安装开始 [root@localhost tmp]# cd vmware-tools-distrib [root@localhost tmp]# ls [root@localhost vmware-tools-distrib]# ./vmware-install.pl //安装开始 8) 最后用“./install.pl”命令来运行该安装程序,然后根据屏幕提示一路回车。到此整个安装过程算是完成了。

资源下载

更多资源
Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

WebStorm

WebStorm

WebStorm 是jetbrains公司旗下一款JavaScript 开发工具。目前已经被广大中国JS开发者誉为“Web前端开发神器”、“最强大的HTML5编辑器”、“最智能的JavaScript IDE”等。与IntelliJ IDEA同源,继承了IntelliJ IDEA强大的JS部分的功能。

用户登录
用户注册