如图,用java处理,想获取以下数据形式该怎么写

图片说明
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 ---> 一,二,三

回答完毕,希望帮到你!