前言
在实际项目开发中,会碰到这样的问题,数据库表结构设计好了,可实体类还没相应地弄出来。实体类的属性命名方法一般是驼峰法,而数据库中的表字段命名方法用的是下划线法。如果表的字段非常多,我们根据设计好的数据库字段再手动敲写一遍驼峰法的属性,这有点费时了。如何迅速地把数据库中的表字段变成我们所需要的驼峰式的属性呢?
解决方法有二,一是通过文本编辑工具,如EditPlus,Notepad++等,利用它们携带的正则替换功能来迅速实现;二是通过自己编写工具类来实现。至于第一种方法操作技巧,不在这边赘述。
第二种方法如下:
以下是自己编写的工具类的代码:
package day0704; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * 驼峰法-下划线互转 * @author cshaper * @since 2015.07.04 * @version 1.0.0 */ public class Underline2Camel { /** * 下划线转驼峰法 * @param line 源字符串 * @param smallCamel 大小驼峰,是否为小驼峰 * @return 转换后的字符串 */ public static String underline2Camel(String line,boolean smallCamel){ if(line==null||"".equals(line)){ return ""; } StringBuffer sb=new StringBuffer(); Pattern pattern=Pattern.compile("([A-Za-z\\d]+)(_)?"); Matcher matcher=pattern.matcher(line); while(matcher.find()){ String word=matcher.group(); sb.append(smallCamel&&matcher.start()==0?Character.toLowerCase(word.charAt(0)):Character.toUpperCase(word.charAt(0))); int index=word.lastIndexOf('_'); if(index>0){ sb.append(word.substring(1, index).toLowerCase()); }else{ sb.append(word.substring(1).toLowerCase()); } } return sb.toString(); } /** * 驼峰法转下划线 * @param line 源字符串 * @return 转换后的字符串 */ public static String camel2Underline(String line){ if(line==null||"".equals(line)){ return ""; } line=String.valueOf(line.charAt(0)).toUpperCase().concat(line.substring(1)); StringBuffer sb=new StringBuffer(); Pattern pattern=Pattern.compile("[A-Z]([a-z\\d]+)?"); Matcher matcher=pattern.matcher(line); while(matcher.find()){ String word=matcher.group(); sb.append(word.toUpperCase()); sb.append(matcher.end()==line.length()?"":"_"); } return sb.toString(); } public static void main(String[] args) { String line="I_HAVE_AN_IPANG3_PIG"; String camel=underline2Camel(line,true); System.out.println(camel); System.out.println(camel2Underline(camel)); } }
运行结果如下:
iHaveAnIpang3Pig
I_HAVE_AN_IPANG3_PIG
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用Java能有一定的帮助,如果有疑问大家可以留言交流。
本文向大家介绍写一个方法把下划线命名转成大驼峰命名相关面试题,主要包含被问及写一个方法把下划线命名转成大驼峰命名时的应答技巧和注意事项,需要的朋友参考一下
问题内容: 在我公司,我们有两种针对Java和sql的样式指南。在Java中,我有一个名为的字段,当我编写sql时,我想为其命名。当我突出显示该短语时,是否有键盘快捷键可以从一个切换到另一个?还是可以做到这一点的插件? 当我问,我也不妨问,如果有办法把到。从Java到clojure风格。 问题答案: 我使用一个名为String Manipulation 的插件,该插件具有您正在寻找的功能(以及更多
本文向大家介绍写个js函数,可以转化下划线命名到驼峰命名?相关面试题,主要包含被问及写个js函数,可以转化下划线命名到驼峰命名?时的应答技巧和注意事项,需要的朋友参考一下 参考回答:
问题内容: 在我已经看到的所有应用程序/示例中(例如wordpress)。列表名称使用下划线而不是驼峰式大小写。我想知道是否存在一些技术上的不兼容性问题,或者这是一个约定?它取决于系统平台(Linux / Windows)还是sql方言(Mysql,postgreSQL,DB2,Oracle等)。例如,在下表中,我使用过骆驼保护套,但还没有任何问题/警告!如果我应该/必须重构我的表,为什么要/必须
我编写了一个应用程序来加载骆驼路线。 我有一个Spring-Camel实例。现在我将加载“模块”来订购我的路线,并有能力通过该模块取消/激活一组路线。 因此,我编写了一个XML文件,并将其解组到Java类中。每个模块现在都是一个Java类。我想在这个Java类中定义骆驼路线。 当我从RouteBuilder扩展Java类时,JAXB不会对其进行编组。 你们中的一些人知道我如何定义我的路由,比如"f
所以我在angularjs服务器中有一个方法,它调用一个方法,为数组中的每个方法返回一个promise。我使用下划线_each在数组中循环。我想等到整个数组被处理后,再调用方法中的最后一行代码... 所以... 这当然行不通。。循环完成并调用“ShowAllMyColStuff”,然后对每个项目执行MakeSuffCooler。所以与async方法交互的正确方法是什么,这样我的ShowAllMyC