模仿log4j的日志字符串格式化log(format,args)

什么也不说,直接看代码。

import java.util.Collection;
import net.xuele.common.utils.format.JsonUtils;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang.ArrayUtils;
import org.apache.commons.lang.StringUtils;
import org.springframework.util.ObjectUtils;

/**
 * 字符串格式化
 * @author wull
 */
public class StringFormat {

	/**
	 * 模仿C#格式化字符串
	 *
	 * @param str
	 * @param args
	 * @return
	 */
	public static String format(String str, String... args) {
		for (int i = 0; i < args.length; i++) {
			str = str.replaceFirst("\\{\\}", args[i]);
		}
		return str;
	}

	public static String format(String str, Object... args) {
		for (int i = 0; i < args.length; i++) {
			str = str.replaceFirst("\\{\\}", String.valueOf(args[i]));
		}
		return str;
	}

	/**
	 * 安全链接字符串
	 *
	 * @param strs
	 * @return
	 */
	public static String softLink(String... strs) {
		StringBuffer sb = new StringBuffer();
		for (String s : strs) {
			sb.append(StringUtils.isEmpty(s) ? "" : s);
		}
		return sb.toString();
	}

	/**
	 * 安全去首位链接字符串
	 *
	 * @param strs
	 * @return
	 */
	public static String softTrimLink(String... strs) {
		StringBuffer sb = new StringBuffer();
		for (String s : strs) {
			sb.append(StringUtils.trimToEmpty(s));
		}
		return sb.toString();
	}

	/**
	 * 安全toString
	 *
	 * @param str
	 * @return
	 */
	public static String toString(Object str) {
		if (null == str)
			return null;
		return str.toString();
	}

	/**
	 * 通过","链接List
	 *
	 * @param strlist
	 * @return
	 */
	public static String formatByComma(Collection<String> strlist) {
		if (CollectionUtils.isEmpty(strlist))
			return "";
		String[] strs = new String[strlist.size()];
		strlist.toArray(strs);
		return StringFormat.formatByComma(strs);
	}

	/**
	 * 将数组轻而易举的转换成用逗号分隔的字符串
	 *
	 * @param strs
	 * @return
	 */
	public static String formatByComma(String... strs) {
		return StringFormat.formatByComma(true, strs);
	}

	/**
	 * 将数组轻而易举的转换成用逗号分隔的字符串
	 *
	 * @param strs
	 * @return
	 */
	public static String formatByComma(boolean filterNull, String... strs) {
		if (!filterNull)
			ArrayUtils.removeElement(strs, null);
		String str = ArrayUtils.toString(strs);
		return StringUtils.substring(str, 1, str.length() - 1);
	}

	/**
	 * 在数组每个元素前后追加数据
	 *
	 * @param array
	 * @param head
	 * @param end
	 * @return
	 */
	public static String[] formatEcho(String head, String end, String... array) {
		if (ObjectUtils.isEmpty(array))
			return null;
		for (int i = 0; i < array.length; i++) {
			if (null == array[i])
				continue;
			array[i] = head + array[i] + end;
		}
		return array;
	}

	/**
	 * 把用","分割的字符串,转换成数组
	 *
	 * @param str
	 * @return
	 */
	public static String[] splitByComma(String str) {
		return StringUtils.split(str, ",");
	}

	public static void main(String[] args) {
		String[] stringArray = { "Red", "Orange", "Blue", "Brown", "Red" };
		System.out.println(StringFormat.formatByComma(stringArray));

		String unitId="unitId";
		Integer sort=0;
		String parentIds="parentIds";
		String str = StringFormat.format("查询原题对应的衍生题param,,unitId={},sort={},parentIds={}", new Object[]{unitId, sort, JsonUtils.toJson(parentIds)});
		System.out.println(str);
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用Java中的`SimpleDateFormat`类和`Calendar`类来解析和处理时间段。以下是一个示例代码,展示了如何将log4j格式的日志按照时间段进行拆分: ```java import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; public class LogSplitter { public static void main(String[] args) { // 定义log4j格式的日志 String log = "2022-01-01 10:30:00 [INFO] This is a log message"; // 定义时间段 String startTime = "2022-01-01 10:00:00"; String endTime = "2022-01-01 11:00:00"; // 使用SimpleDateFormat解析时间格式 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); try { // 将起始时间和结束时间转换为Date对象 Date start = dateFormat.parse(startTime); Date end = dateFormat.parse(endTime); // 使用Calendar类进行日期比较和操作 Calendar calendar = Calendar.getInstance(); calendar.setTime(start); // 循环处理日志 while (calendar.getTime().before(end)) { // 格式化当前日期时间 String currentDateTime = dateFormat.format(calendar.getTime()); // 判断日志是否在当前时间段内 if (log.startsWith(currentDateTime)) { // 拆分日志 String[] logParts = log.split("\\["); String logLevel = logParts[1].split("]")[0].trim(); String logMessage = logParts[2].trim(); // 输出拆分后的日志 System.out.println("Level: " + logLevel); System.out.println("Message: " + logMessage); } // 增加一分钟 calendar.add(Calendar.MINUTE, 1); } } catch (Exception e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们首先定义了一个log4j格式的日志字符串,然后定义了起始时间和结束时间。接下来,我们使用`SimpleDateFormat`类将起始时间和结束时间转换为`Date`对象。然后,我们使用`Calendar`类进行日期比较和操作。 在循环中,我们首先将当前日期时间格式化字符串,然后判断日志是否在当前时间段内。如果是,则我们使用`split`方法拆分日志字符串,获取日志级别和日志消息,并进行输出。 请注意,上述代码仅适用于log4j格式的日志,并且假设日志中的日期时间位于日志字符串的开头部分。如果您的日志格式有所不同,您需要相应地调整代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值