热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java代码自动对齐_java程序实现编写代码时变量名垂直对齐的风格

记录英语单词时,想把英语和中文翻译分别对齐,有些人写代码喜欢把变量按这种方式对齐。在网上没搜到相关方法,于是自己试着写代码去实现ÿ

记录英语单词时,想把英语和中文翻译分别对齐,有些人写代码喜欢把变量按这种方式对齐。在网上没搜到相关方法,于是自己试着写代码去实现,原本以为很简单,写的时候才发现有不少问题。先看效果:

普通的

对齐前:

f2b5980235eb773004cf55f29da08060.png

对齐后:

3eed350f83518c3a6546c6e64c9ee79f.png

发挥点创意

对齐前:

7a3e58607dc49befe616599936018c19.png

对齐后:

1771a534d45a793613d8445c115e7cfd.png

实现

实现的思路比较简单,读取文本文件,按正则分割,找出最长的部分,补齐空格,输出。

看起来相当简单,花了一个多小时,就写出来了,马上运行,发现输出一团糟,去查看每个部分的字符数,个数是一样的,网上一搜,原来跟字体有关系,好吧,那换个等宽的字体。换好字体后有些地方已经对齐了,有些地方还是没对齐,发现是中文的问题,中文宽度与英文宽度不相同,于是首先根据正则去判断字符是中文还是英文,然后自己实现计算字符长度的方法,在判断中文字符上折腾了许久,因为标点符号等等都要考虑进去,反正是来来回回试了好久,对Unicode编码范围不熟悉,没办法。终于,好像都搞定了,反复测试,突然发现第一行的对齐少了一个空格,尼玛,这是怎么回事啊,Debug发现第一行的最开始有一个奇怪的字符"\uFEFF",这他妈是什么鬼,上网搜,发现是Unicode编码的什么BOM头,好吧,不管它是什么鬼,直接把它去掉了……

反正是遇到了各种各样的问题,与字符集相关的问题实在是太头疼了。另外,我没有去处理编码的问题,所以文本的编码需要和IDE的编码保持一致,否则就会产生乱码。

源码

看过《重构》和《代码整洁之道》之后,写代码时时刻想着要写干净点,扩展性强点,经过反复修改,最终自己觉得还行吧,当然,肯定有不少值得改进的地方,现在就这样吧。

App.java

1 packagetextalign;2

3 importjava.io.IOException;4

5 /**

6 *@authortingl7 *@version2017/9/278 */

9 public classApp {10

11 public static voidmain(String[] args) {12 long start =System.currentTimeMillis();13

14 String filePath = "C:\\Users\\tingl\\Desktop\\Test2.txt";15 TextAlign textAlign = new TextAlign(/*",|。|,|[.]|( {2,})|\t| +"*/);16

17 if (args.length > 0) {18 filePath = args[0];19 }20 try{21 textAlign.align(filePath);22 } catch(IOException e) {23 e.printStackTrace();24 }25

26 System.out.println(System.currentTimeMillis() -start);27 }28 }

TextAlign.java

1 packagetextalign;2

3 importjava.io.IOException;4 importjava.util.List;5 importjava.util.regex.Pattern;6

7 /**

8 *@authortingl9 *@version2017/9/2710 */

11 public classTextAlign {12 private static final String CHINESE_CHARACTER = "[\u4e00-\u9fa5]|[\uFE30-\uFFA0]|[\u3000-\u303F]";13 private static final Pattern CHINESE_CHARACTER_PATTERN =Pattern.compile(CHINESE_CHARACTER);14 private static final int SEPARATE_SPACE_AMOUNT = 4;15

16 privateTextAlignFileUtil textAlignFileUtil;17 private ListtextLines;18 private int[] longestBlockLengths;19

20 publicTextAlign() {21 textAlignFileUtil = newTextAlignFileUtil();22 }23

24 publicTextAlign(String spiltRegex) {25 textAlignFileUtil = newTextAlignFileUtil(spiltRegex);26 }27

28 public void align(String filePath) throwsIOException {29 textLines =textAlignFileUtil.readToList(filePath);30 initLongestBlockLengths();31 fillTextLinesBySpaces();32 textAlignFileUtil.write();33 }34

35 private voidinitLongestBlockLengths() {36 int longestArrayLength = 0;37 for(String[] blocks : textLines) {38 if (blocks.length >longestArrayLength) {39 longestArrayLength =blocks.length;40 }41 }42 longestBlockLengths = new int[longestArrayLength];43 fillLongestBlockLengths();44 }45

46 private voidfillLongestBlockLengths() {47 for(String[] blocks : textLines) {48 if (blocks.length <2) continue;49 for (int i &#61; 0; i longestBlockLengths[i]) {52 longestBlockLengths[i] &#61;length;53 }54 }55 }56 }57

58 private intstringLengthFitWidth(String s) {59 if (!CHINESE_CHARACTER_PATTERN.matcher(s).find()) {60 returns.length();61 }62 int length &#61; 0;63 for (String c : s.split("")) {64 if(CHINESE_CHARACTER_PATTERN.matcher(c).find()) {65 length&#43;&#43;;66 }67 length&#43;&#43;;68 }69 returnlength;70 }71

72 private voidfillTextLinesBySpaces() {73 for(String[] blocks : textLines) {74 for (int i &#61; 0; i

82 private String spaces(intspaceAmount) {83 StringBuilder spaces &#61; newStringBuilder();84 for (int i &#61; 0; i

TextAlignFileUtil.java

1 packagetextalign;2

3 import java.io.*;4 importjava.util.ArrayList;5 importjava.util.Arrays;6 importjava.util.List;7

8 /**

9 *&#64;authortingl10 *&#64;version2017/9/2711 */

12 classTextAlignFileUtil {13 private static final String FILENAME_POSTFIX &#61; "_aligned";14 private String spiltRegex &#61; "( {2,})|\t";15 private ListtextLines;16 privateString outPath;17

18 TextAlignFileUtil() {19 }20

21 TextAlignFileUtil(String spiltRegex) {22 this.spiltRegex &#61;spiltRegex;23 }24

25 List readToList(String path) throwsIOException {26 File file &#61; newFile(path);27 returnreadToList(file);28 }29

30 private List readToList(File file) throwsIOException {31 getOutPath(file.getAbsolutePath());32 try (BufferedReader reader &#61; new BufferedReader(newFileReader(file))) {33 textLines &#61; new ArrayList<>();34 String line;35 while ((line &#61; reader.readLine()) !&#61; null) {36 textLines.add(removeEmptyAndTrim(line.split(spiltRegex)));37 }38 }39 removeBomHead();40 returntextLines;41 }42

43 private voidgetOutPath(String srcPath) {44 int dotPosition &#61; srcPath.lastIndexOf(".");45 outPath &#61; srcPath.substring(0, dotPosition) &#43; FILENAME_POSTFIX &#43;srcPath.substring(dotPosition);46 if (newFile(outPath).exists()) {47 getOutPath(outPath);48 }49 }50

51 privateString[] removeEmptyAndTrim(String[] src) {52 for (int i &#61; 0; i

56 List dest &#61; new ArrayList<>(Arrays.asList(src));57 dest.removeIf(String::isEmpty);58 return dest.toArray(new String[0]);59 }60

61 private voidremoveBomHead() {62 String[] blocks &#61; textLines.get(0);63 blocks[0] &#61; blocks[0].replace("\uFEFF", "");64 }65

66 void write() throwsIOException {67 try (BufferedWriter writer &#61; new BufferedWriter(newFileWriter(outPath))) {68 for(String[] blocks : textLines) {69 writer.write(getLine(blocks));70 writer.newLine();71 writer.flush();72 }73 }74 }75

76 privateString getLine(String[] blocks) {77 StringBuilder sb &#61; newStringBuilder();78 for(String block : blocks) {79 sb.append(block);80 }81 returnsb.toString();82 }83 }



推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 数组的排序:数组本身有Arrays类中的sort()方法,这里写几种常见的排序方法。(1)冒泡排序法publicstaticvoidmain(String[]args ... [详细]
  • 面向对象之3:封装的总结及实现方法
    本文总结了面向对象中封装的概念和好处,以及在Java中如何实现封装。封装是将过程和数据用一个外壳隐藏起来,只能通过提供的接口进行访问。适当的封装可以提高程序的理解性和维护性,增强程序的安全性。在Java中,封装可以通过将属性私有化并使用权限修饰符来实现,同时可以通过方法来访问属性并加入限制条件。 ... [详细]
author-avatar
秋荼凝脂_697
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有