A表数据,转换形式插入到B表中,用java程序处理,有没有大神贴段代码做个参考啊
你可以用这个方法试一下
private Map<Integer, List<String>> convert(Map<Integer, List<String>> map) {
HashMap<Integer, List<String>> newMap = new HashMap<>();
Set<Entry<Integer, List<String>>> entrySet = map.entrySet();
int i = 0;
for (Iterator<Entry<Integer, List<String>>> iterator = entrySet
.iterator(); iterator.hasNext();) {
Entry<Integer, List<String>> entry = iterator.next();
List<String> list = entry.getValue();
String[] str1 = list.get(1).split(",");
String[] str2 = list.get(2).split(",");
for (int index = 0; index < str1.length; index++) {
list = new ArrayList<>();
list.add(++i+"");
list.add(str1[index]);
if (index < str2.length) {
list.add(str2[index]);
}
newMap.put(i, list);
}
}
return newMap;
}
map的内容可以自己加,就像下面这样
HashMap<Integer, List<String>> map = new HashMap<>();
ArrayList<String> list = new ArrayList<>();
list.add("1");
list.add("ACS,DFG,DC");
list.add("一,二,三");
map.put(1, list);
最后把它输出就可以了
看这里:https://blog.csdn.net/ying890/article/details/50145673
java的方式,伪代码如下:
for (String s1 in rs["字段1"].split(","))
for (String s2 in rs["字段2"].split(","))
{
插入表二(s1, s2); //对应的就是其中一个逗号的部分
}
正则实现
import java.util.HashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang3.StringUtils;
/**
*
* 字符串转换处理
*
* @author 00fly
* @version [版本号, 2018年10月14日]
* @see [相关类/方法]
* @since [产品/模块版本]
*/
public class Converter
{
// 被转换字符串对应关系
private static Map<String, String> map;
private static Pattern pattern;
static
{
map = new HashMap<>();
map.put("ACS", "一");
map.put("DFG", "二");
map.put("DC", "三");
String patternString = "(" + StringUtils.join(map.keySet(), "|") + ")";
pattern = Pattern.compile(patternString);
}
/**
* 字符串转换
*
* @param src 源字符串
* @return 替换后的值
* @see [类、类#方法、类#成员]
*/
private static String convert(String src)
{
Matcher matcher = pattern.matcher(src);
StringBuffer sb = new StringBuffer();
while (matcher.find())
{
matcher.appendReplacement(sb, map.get(matcher.group(1)));
}
matcher.appendTail(sb);
return sb.toString();
}
/**
* main
*
* @param args
* @see [类、类#方法、类#成员]
*/
public static void main(String[] args)
{
String src = "ACS,DFG,DC";
String target = convert(src);
System.out.println(src + " ---> " + target);
}
}
运行结果
ACS,DFG,DC ---> 一,二,三
回答完毕,希望帮到你!