public void MakeDup(string rank_file_diff1_path, string rank_file_diff2_path, InputOutputOption iooption, RankingMethod ranking_method) { if (!File.Exists(rank_file_diff1_path)) { throw new Exception("ランクファイル(1)が存在しません。"); } if (!File.Exists(rank_file_diff2_path)) { throw new Exception("ランクファイル(2)が存在しません。"); } msgout_.Write("重複チェック中…\r\n"); RankFile rank_file_diff1 = new RankFile(rank_file_diff1_path, iooption.GetRankFileCustomFormat()); RankFile rank_file_diff2 = new RankFile(rank_file_diff2_path, iooption.GetRankFileCustomFormat()); List <Video> video_list_diff2 = rank_file_diff2.GetVideoList(); List <Video> video_list = new List <Video>(); for (int i = 0; i < rank_file_diff1.Count; ++i) { Video video = rank_file_diff1.GetVideo(i); int index = RankFile.SearchVideo(video_list_diff2, video.video_id); if (index >= 0) { video_list.Add(video); } } RankFile rank_file = new RankFile(video_list, iooption.GetRankFileCustomFormat()); rank_file.Sort(ranking_method); iooption.OutputRankFile(rank_file, ranking_method); msgout_.Write("重複チェックが終了しました。\r\n"); }
public void UpdatePoint(string rank_file_diff1_path, string rank_file_diff2_path, InputOutputOption iooption, RankingMethod ranking_method) { bool exists_rank_file1 = File.Exists(rank_file_diff1_path); if (!exists_rank_file1) { throw new Exception("ランクファイル(1)が存在しません。"); } bool exists_rank_file2 = File.Exists(rank_file_diff2_path); if (!exists_rank_file2) { throw new Exception("ランクファイル(2)が存在しません。"); } msgout_.Write("ポイント更新中…\r\n"); RankFile rank_file_diff1 = new RankFile(rank_file_diff1_path, iooption.GetRankFileCustomFormat()); RankFile rank_file_diff2 = new RankFile(rank_file_diff2_path, iooption.GetRankFileCustomFormat()); List <Video> video_list_diff2 = rank_file_diff2.GetVideoList(); List <Video> video_list = new List <Video>(); for (int i = 0; i < rank_file_diff1.Count; ++i) { Video video = rank_file_diff1.GetVideo(i); int index = RankFile.SearchVideo(rank_file_diff2.GetVideoList(), video.video_id); if (index >= 0) { video.title = video_list_diff2[index].title; video.tag_set = video_list_diff2[index].tag_set; video.point = video_list_diff2[index].point; video.description = video_list_diff2[index].description; video_list.Add(video); } } RankFile rank_file = new RankFile(video_list, iooption.GetRankFileCustomFormat()); rank_file.Sort(ranking_method); iooption.OutputRankFile(rank_file, ranking_method); msgout_.Write("ポイント更新が終了しました。\r\n"); }
public void CalculateSum(InputOutputOption iooption, RankingMethod ranking_method) { RankFile rank_file = iooption.GetRankFile(); msgout_.Write("------------------------------------------\r\n"); msgout_.Write("内訳: 再生数, コメント数, マイリスト数, ポイント\r\n"); RankPoint point = new RankPoint(); point.view = point.res = point.mylist = 0; List <Video> video_list = rank_file.GetVideoList(); List <int> view_list = new List <int>(); List <int> res_list = new List <int>(); List <int> mylist_list = new List <int>(); List <int> point_list = new List <int>(); for (int i = 0; i < video_list.Count; ++i) { point += video_list[i].point; view_list.Add(video_list[i].point.view); res_list.Add(video_list[i].point.res); mylist_list.Add(video_list[i].point.mylist); point_list.Add(video_list[i].point.CalcScore(ranking_method)); } msgout_.Write("合計: " + point.view + ", " + point.res + ", " + point.mylist + ", " + point.CalcScore(ranking_method) + "\r\n"); if (video_list.Count > 0) { msgout_.Write("平均: " + ((double)point.view / video_list.Count).ToString("0.00") + ", " + ((double)point.res / video_list.Count).ToString("0.00") + ", " + ((double)point.mylist / video_list.Count).ToString("0.00") + ", " + ((double)point.CalcScore(ranking_method) / video_list.Count).ToString("0.00") + "\r\n"); msgout_.Write("中央値: " + CalculateMedian(view_list) + ", " + CalculateMedian(res_list) + ", " + CalculateMedian(mylist_list) + ", " + CalculateMedian(point_list) + "\r\n"); msgout_.Write("最大値: " + view_list[view_list.Count - 1] + ", " + res_list[res_list.Count - 1] + ", " + mylist_list[mylist_list.Count - 1] + ", " + point_list[point_list.Count - 1] + "\r\n"); msgout_.Write("最小値: " + view_list[0] + ", " + res_list[0] + ", " + mylist_list[0] + ", " + point_list[0] + "\r\n"); } }
public void MakeDiff(string rank_file_diff1_path, string rank_file_diff2_path, InputOutputOption iooption, RankingMethod ranking_method, DateTime exclusion_date) { if (!File.Exists(rank_file_diff1_path)) { throw new Exception("ランクファイル(1)が存在しません。"); } if (!File.Exists(rank_file_diff2_path)) { throw new Exception("ランクファイル(2)が存在しません。"); } msgout_.Write("差分を計算中…\r\n"); RankFile rank_file_diff1 = new RankFile(rank_file_diff1_path, iooption.GetRankFileCustomFormat()); RankFile rank_file_diff2 = new RankFile(rank_file_diff2_path, iooption.GetRankFileCustomFormat()); List <Video> video_list_diff2 = rank_file_diff2.GetVideoList(); List <Video> video_list = new List <Video>(); for (int i = 0; i < rank_file_diff1.Count; ++i) { Video video = rank_file_diff1.GetVideo(i); int index = RankFile.SearchVideo(video_list_diff2, video.video_id); if (index >= 0) { video.point -= video_list_diff2[index].point; video_list.Add(video); } else { if (exclusion_date <= video.submit_date) { video_list.Add(video); } } } RankFile rank_file = new RankFile(video_list, iooption.GetRankFileCustomFormat()); rank_file.Sort(ranking_method); iooption.OutputRankFile(rank_file, ranking_method); msgout_.Write("差分を計算しました。\r\n"); }