标注的Trigger的位置是否与句子中的位置相同

package AboutProtein;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

public class LocRight
{
	public static void main(String args[])
	{
		try
		{			
			File file = new File("F:\\generate jar\\2013_BioEvent");
			File[] files = file.listFiles();
			for(int fileId = 0; fileId < files.length; fileId++)
			{
				String fileName = files[fileId].getName();
				FileReader frAll = new FileReader(files[fileId]);
				BufferedReader brAll = new BufferedReader(frAll);
				
				FileWriter fw = new FileWriter("F:\\generate jar\\2013BioEvent\\" + fileName);
				BufferedWriter bw = new BufferedWriter(fw);
				
				List<Protein> proAll = new ArrayList<Protein>();
				List<Protein> proPart = new ArrayList<Protein>();
				List<Trigger> triList = new ArrayList<Trigger>();
				//List<Trigger> problem = new ArrayList<Trigger>();
				List<String> event = new ArrayList<String>();
				String[] sent = new String[1000];
				List<String> sentList = new ArrayList<String>();
				if(fileName.equals("PMC-1134658-00-TIAB.txt"))
				{
					System.out.println(fileName);
				}
				String str;
				while((str = brAll.readLine()) != null)
				{
					if(str.length() == 0)
					{
						for(int tId = 0; tId < triList.size(); tId++)
						{
							Trigger tr = triList.get(tId);
							int start = tr.triggerStart;
							int end = tr.triggerEnd;
							String name = tr.triggerName;
							if(start == end)
							{
								String word = sentList.get(start);
								if(!word.equals(name))
								{
									System.out.println(fileName);
									System.out.println(name + " " + word);
								}
							}else if(start < end)
							{
								StringBuffer sb = new StringBuffer();
								for(int j = start; j <= end; j++)
								{
									if(j == end)
									{
										sb.append(sentList.get(j));
									}else
									{
										sb.append(sentList.get(j) + " ");
									}
								}
								String word = sb.toString();
								if(!word.equals(name))
								{
									System.out.println(fileName);
									System.out.println(name + " " + word);
								}
							}else 
							{
								System.out.println("have a problem");
							}
						}
						proAll.clear();
						proPart.clear();
						triList.clear();
						sentList.clear();
					}else if(str.startsWith("#"))
					{
						String[] proStr = str.split(" ");
						
						StringBuffer proB = new StringBuffer();				    	
						for(int prosId = 4; prosId < proStr.length; prosId++)
						{
							if(prosId == proStr.length - 1)
							{
								proB.append(proStr[prosId]);
							}else
							{
								proB.append(proStr[prosId] + " ");
							}
						}	
						String proName = proB.toString();						
						Protein prot = new Protein();
						prot.proId = proStr[1];
						prot.proStart = Integer.parseInt(proStr[2]);
						prot.proEnd = Integer.parseInt(proStr[3]);
						prot.proName = proName;						
						proAll.add(prot);
						
					}else if(str.startsWith("$"))
					{
                        String[] proStr = str.split(" ");
						
						StringBuffer proB = new StringBuffer();				    	
						for(int prosId = 4; prosId < proStr.length; prosId++)
						{
							if(prosId == proStr.length - 1)
							{
								proB.append(proStr[prosId]);
							}else
							{
								proB.append(proStr[prosId] + " ");
							}
						}	
						String proName = proB.toString();						
						Protein prot = new Protein();
						prot.proId = proStr[1];
						prot.proStart = Integer.parseInt(proStr[2]);
						prot.proEnd = Integer.parseInt(proStr[3]);
						prot.proName = proName;						
						proPart.add(prot);
					}else if(str.startsWith("@"))
					{
						String[] trit = str.split(" ");
						
						StringBuffer triB = new StringBuffer();				    	
						for(int prosId = 5; prosId < trit.length; prosId++)
						{
							if(prosId == trit.length - 1)
							{
								triB.append(trit[prosId]);
							}else
							{
								triB.append(trit[prosId] + " ");
							}
						}	
						String triName = triB.toString();
						
						Trigger trig = new Trigger();
						trig.triggerId = trit[1];
						trig.triggerType = trit[2];
						trig.triggerStart = Integer.parseInt(trit[3]);
						trig.triggerEnd = Integer.parseInt(trit[4]);
						trig.triggerName = triName;
						triList.add(trig);
						
					}else if(str.startsWith("%"))
					{
						event.add(str);
					}else
					{						
						sent = str.split(" ");
						for(int j = 0; j < sent.length; j++)
						{
							sentList.add(sent[j]);
						}						
					}
				}
				brAll.close();
				frAll.close();
			}
		}catch(IOException io)
		{
			io.printStackTrace();
		}
	}		
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值