rss 뉴스제목글을 지정된 언론사별로 가져와서 홈페이지에 출력하려고 합니다.
아래 코드처럼 짜집기를 했는데
일단, 언론사별 rss 뉴스제목를 가져와서 출력이 되는거 까지는 이상이 없습니다
문제는...
아래 코드처럼 하면 ... 있는대로 다 가져오다 보니 약 100여개의 '뉴스제목'이 출력 되어버립니다.
홈페이지에는 '최신시간'순으로 or '기타'기준으로...
언론사구분없이 통틀어서 10여개 정도의 rss 뉴스제목만 홈페이지에 출력하고 싶습니다.
코드의 어느부분을 어떻게 손봐야 할런지요...??
도움글을 좀 부탁드립니다.
---------- 코드참고 ------------------------
$news = array(
"sports" => array("스포츠서울","http://www.sportsseoul.com/rss/rss.asp?cp_flag=1&cat_flag=1"),
"ohmynews" => array("오마이뉴스","http://rss.ohmynews.com/rss/ohmynews.xml"),
"chosun" => array("조선일보","http://newsplus.chosun.com/hitdata/xml/index/index.xml"),
"hani" => array("한겨레신문","http://www.hani.co.kr/rss/newsrank/"),
"kbench" => array("케이벤치","http://rss.kbench.com/news.xml"),
"YTN뉴스" => array("YTN","http://www.yonhapnews.co.kr/RSS/sokbo.xml")
);
"sports" => array("스포츠서울","http://www.sportsseoul.com/rss/rss.asp?cp_flag=1&cat_flag=1"),
"ohmynews" => array("오마이뉴스","http://rss.ohmynews.com/rss/ohmynews.xml"),
"chosun" => array("조선일보","http://newsplus.chosun.com/hitdata/xml/index/index.xml"),
"hani" => array("한겨레신문","http://www.hani.co.kr/rss/newsrank/"),
"kbench" => array("케이벤치","http://rss.kbench.com/news.xml"),
"YTN뉴스" => array("YTN","http://www.yonhapnews.co.kr/RSS/sokbo.xml")
);
$ns = $HTTP_GET_VARS["ns"];
if(empty($ns)){ $ns = array_keys($news); }
if(empty($ns)){ $ns = array_keys($news); }
$newsList = array();
while (list($key, $value) = each ($news)) {
$url = $value[1];
$rss = new RSSReader($url,true,60,$DOCUMENT_ROOT."/newsmowa/cache");
$response = $rss->Read();
while (list($key, $value) = each ($news)) {
$url = $value[1];
$rss = new RSSReader($url,true,60,$DOCUMENT_ROOT."/newsmowa/cache");
$response = $rss->Read();
foreach($rss->getItems() as $item){
if(isChoice($key)){
if(isset($item["dc:date"])) $item["pubdate"] = $item["dc:date"];
//array_push($newsList,array($value[0],$item["title"],$item["link"],$item["description"],$item["pubdate"]));
array_push($newsList,
array(
NAME => $value[0],
TITLE => $item["title"],
LINK => $item["link"],
DESCRIPTION => $item["description"],
PUBDATE => $item["pubdate"],
TOPUBDATE => _Topubdate($item["pubdate"]),
IDXPUBDATE => _Topubdate($item["pubdate"],"YmdHis")
)
);
}
}
if(isset($item["dc:date"])) $item["pubdate"] = $item["dc:date"];
//array_push($newsList,array($value[0],$item["title"],$item["link"],$item["description"],$item["pubdate"]));
array_push($newsList,
array(
NAME => $value[0],
TITLE => $item["title"],
LINK => $item["link"],
DESCRIPTION => $item["description"],
PUBDATE => $item["pubdate"],
TOPUBDATE => _Topubdate($item["pubdate"]),
IDXPUBDATE => _Topubdate($item["pubdate"],"YmdHis")
)
);
}
}
$rss->free();
unset($rss);
}
unset($rss);
}
usort($newsList,"cmp");
echo "<html><head><title>뉴스모와</title>\n";
echo "<style><!-- BODY,TD,SELECT { FONT: 9pt Arial; LINE-HEIGHT: 17px;} //--></style>\n";
echo "<body>";
echo "<form>";
echo "<table width=100% border=1>\n";
echo "<tr><td>\n";
echo "<style><!-- BODY,TD,SELECT { FONT: 9pt Arial; LINE-HEIGHT: 17px;} //--></style>\n";
echo "<body>";
echo "<form>";
echo "<table width=100% border=1>\n";
echo "<tr><td>\n";
foreach($news as $key => $value) {
$checked = isChoice($key)? "checked":"";
echo "<input type=checkbox name=ns[] value=$key $checked> $value[0]\n";
}
echo "<input type=submit value=\"조회\"></td></tr>\n";
echo "</table>";
echo "</form>";
echo "</table>";
echo "</form>";
echo "<table width=100% border=0>\n";
echo "<tr><td align=center>뉴스제목</td><td align=center>출처</td><td align=center>발행일</td></tr>\n";
foreach($newsList as $list){
printf("<tr><td><a href=\"%s\" target=_blank>%s</td><td align=center>%s</td><td align=center>%s</td></tr>\n",
$list[LINK],$list[TITLE],$list[NAME],$list[TOPUBDATE]);
}
echo "</table>";
echo "<tr><td align=center>뉴스제목</td><td align=center>출처</td><td align=center>발행일</td></tr>\n";
foreach($newsList as $list){
printf("<tr><td><a href=\"%s\" target=_blank>%s</td><td align=center>%s</td><td align=center>%s</td></tr>\n",
$list[LINK],$list[TITLE],$list[NAME],$list[TOPUBDATE]);
}
echo "</table>";
echo "</body></html>\n";
?>
?>
댓글 1개
영리한바부
13년 전
이미 처리 하셨는지 모르겠는데 혹시 해결하지 못하셨다면
참고 해서 수정해보십시요
// xml결과값을 모두 배열에 저장구현
// 다중배열 정렬
foreach (뉴스배열 as $key => $row) {
$sort[$key] = $row[' IDXPUBDATE'];
}
array_multisort($sort, SORT_ASC, 뉴스배열); // SORT_ASC , SORT_DESC
// 원하는 수만큼 뉴스 출력구현
http://php.net/manual/en/function.array-multisort.php
참고 해서 수정해보십시요
// xml결과값을 모두 배열에 저장구현
// 다중배열 정렬
foreach (뉴스배열 as $key => $row) {
$sort[$key] = $row[' IDXPUBDATE'];
}
array_multisort($sort, SORT_ASC, 뉴스배열); // SORT_ASC , SORT_DESC
// 원하는 수만큼 뉴스 출력구현
http://php.net/manual/en/function.array-multisort.php
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 4430 | 13년 전 | 828 | ||
| 4429 | 13년 전 | 1151 | ||
| 4428 | 13년 전 | 1940 | ||
| 4427 | 13년 전 | 1059 | ||
| 4426 | 13년 전 | 521 | ||
| 4425 | 13년 전 | 9883 | ||
| 4424 |
|
13년 전 | 850 | |
| 4423 |
|
13년 전 | 728 | |
| 4422 |
aequum
|
13년 전 | 1299 | |
| 4421 | 13년 전 | 2415 | ||
| 4420 | 13년 전 | 1205 | ||
| 4419 | 13년 전 | 889 | ||
| 4418 |
한번잘해보자
|
13년 전 | 672 | |
| 4417 | 13년 전 | 1579 | ||
| 4416 | 13년 전 | 873 | ||
| 4415 | 13년 전 | 2254 | ||
| 4414 | 13년 전 | 680 | ||
| 4413 | 13년 전 | 678 | ||
| 4412 | 13년 전 | 820 | ||
| 4411 | 13년 전 | 1438 | ||
| 4410 |
|
13년 전 | 731 | |
| 4409 | 13년 전 | 2167 | ||
| 4408 |
visualp
|
13년 전 | 535 | |
| 4407 |
visualp
|
13년 전 | 3090 | |
| 4406 |
visualp
|
13년 전 | 3258 | |
| 4405 |
visualp
|
13년 전 | 3154 | |
| 4404 |
visualp
|
13년 전 | 2978 | |
| 4403 |
|
13년 전 | 672 | |
| 4402 |
gender
|
13년 전 | 628 | |
| 4401 | 13년 전 | 1119 | ||
| 4400 |
aequum
|
13년 전 | 1380 | |
| 4399 | 13년 전 | 588 | ||
| 4398 | 13년 전 | 671 | ||
| 4397 |
|
13년 전 | 583 | |
| 4396 |
aequum
|
13년 전 | 4664 | |
| 4395 |
|
13년 전 | 571 | |
| 4394 |
aequum
|
13년 전 | 4935 | |
| 4393 |
|
13년 전 | 1269 | |
| 4392 | 13년 전 | 1061 | ||
| 4391 |
mirrV
|
13년 전 | 541 | |
| 4390 |
파워웹프로
|
13년 전 | 709 | |
| 4389 | 13년 전 | 1228 | ||
| 4388 |
Coding
|
13년 전 | 707 | |
| 4387 |
aequum
|
13년 전 | 1366 | |
| 4386 | 13년 전 | 870 | ||
| 4385 | 13년 전 | 722 | ||
| 4384 | 13년 전 | 788 | ||
| 4383 | 13년 전 | 2901 | ||
| 4382 | 13년 전 | 614 | ||
| 4381 | 13년 전 | 1188 | ||
| 4380 | 13년 전 | 815 | ||
| 4379 |
|
13년 전 | 751 | |
| 4378 | 13년 전 | 664 | ||
| 4377 | 13년 전 | 3300 | ||
| 4376 |
aequum
|
13년 전 | 1217 | |
| 4375 |
클로로다인
|
13년 전 | 651 | |
| 4374 |
DDFACTORY
|
13년 전 | 720 | |
| 4373 |
까탈스런ET
|
13년 전 | 709 | |
| 4372 | 13년 전 | 811 | ||
| 4371 | 13년 전 | 573 | ||
| 4370 |
|
13년 전 | 651 | |
| 4369 |
프리프리닷
|
13년 전 | 1306 | |
| 4368 | 13년 전 | 3174 | ||
| 4367 |
soing
|
13년 전 | 1585 | |
| 4366 |
|
13년 전 | 685 | |
| 4365 |
|
13년 전 | 623 | |
| 4364 |
|
13년 전 | 760 | |
| 4363 |
|
13년 전 | 624 | |
| 4362 |
|
13년 전 | 728 | |
| 4361 |
|
13년 전 | 843 | |
| 4360 |
|
13년 전 | 650 | |
| 4359 |
|
13년 전 | 3128 | |
| 4358 |
|
13년 전 | 3042 | |
| 4357 | 13년 전 | 841 | ||
| 4356 | 13년 전 | 1342 | ||
| 4355 | 13년 전 | 968 | ||
| 4354 | 13년 전 | 816 | ||
| 4353 | 13년 전 | 3374 | ||
| 4352 | 13년 전 | 2377 | ||
| 4351 | 13년 전 | 1966 | ||
| 4350 |
|
13년 전 | 1886 | |
| 4349 | 13년 전 | 664 | ||
| 4348 |
aequum
|
13년 전 | 1423 | |
| 4347 | 13년 전 | 663 | ||
| 4346 |
|
13년 전 | 566 | |
| 4345 | 13년 전 | 598 | ||
| 4344 |
aequum
|
13년 전 | 1008 | |
| 4343 |
|
13년 전 | 1041 | |
| 4342 |
aequum
|
13년 전 | 1643 | |
| 4341 | 13년 전 | 810 | ||
| 4340 |
2번호랑이
|
13년 전 | 1009 | |
| 4339 |
|
13년 전 | 1172 | |
| 4338 | 13년 전 | 1167 | ||
| 4337 | 13년 전 | 519 | ||
| 4336 |
aequum
|
13년 전 | 1710 | |
| 4335 | 13년 전 | 891 | ||
| 4334 | 13년 전 | 1195 | ||
| 4333 |
Sturmvogel
|
13년 전 | 964 | |
| 4332 |
aequum
|
13년 전 | 1283 | |
| 4331 |
aequum
|
13년 전 | 1406 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기