热门标签 | 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 }



推荐阅读
  • andr ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • Java编程实践:深入理解方法重载
    本文介绍了Java中方法重载的概念及其应用。通过多个示例,详细讲解了如何在同一类中定义具有相同名称但不同参数列表的方法,以实现更灵活的功能调用。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • 本文探讨了在Java多线程环境下,如何确保具有相同key值的线程能够互斥执行并按顺序输出结果。通过优化代码结构和使用线程安全的数据结构,我们解决了线程同步问题,并实现了预期的并发行为。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
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社区 版权所有