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
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7030 | 11년 전 | 1429 | ||
| 7029 |
|
11년 전 | 3252 | |
| 7028 |
|
11년 전 | 1157 | |
| 7027 | 11년 전 | 1017 | ||
| 7026 | 11년 전 | 2098 | ||
| 7025 |
어려워요잉
|
11년 전 | 2749 | |
| 7024 | 11년 전 | 2109 | ||
| 7023 | 11년 전 | 3146 | ||
| 7022 |
Shhhh
|
11년 전 | 1545 | |
| 7021 |
|
11년 전 | 3286 | |
| 7020 | 11년 전 | 797 | ||
| 7019 |
막돼먹은영애
|
11년 전 | 1089 | |
| 7018 | 11년 전 | 1967 | ||
| 7017 | 11년 전 | 2330 | ||
| 7016 | 11년 전 | 1035 | ||
| 7015 | 11년 전 | 2840 | ||
| 7014 | 11년 전 | 3034 | ||
| 7013 | 11년 전 | 1520 | ||
| 7012 |
|
11년 전 | 2203 | |
| 7011 | 11년 전 | 1050 | ||
| 7010 | 11년 전 | 1408 | ||
| 7009 |
|
11년 전 | 1088 | |
| 7008 | 11년 전 | 2276 | ||
| 7007 | 11년 전 | 2193 | ||
| 7006 |
|
11년 전 | 1184 | |
| 7005 | 11년 전 | 5315 | ||
| 7004 | 11년 전 | 2367 | ||
| 7003 | 11년 전 | 3082 | ||
| 7002 | 11년 전 | 1931 | ||
| 7001 | 11년 전 | 988 | ||
| 7000 | 11년 전 | 2055 | ||
| 6999 |
|
11년 전 | 2176 | |
| 6998 | 11년 전 | 1891 | ||
| 6997 |
네이비칼라
|
11년 전 | 1502 | |
| 6996 | 11년 전 | 963 | ||
| 6995 |
|
11년 전 | 1870 | |
| 6994 | 11년 전 | 2586 | ||
| 6993 |
kimsdesign
|
11년 전 | 1310 | |
| 6992 |
|
11년 전 | 2782 | |
| 6991 | 11년 전 | 1725 | ||
| 6990 | 11년 전 | 4481 | ||
| 6989 | 11년 전 | 1868 | ||
| 6988 |
네이비컬러
|
11년 전 | 2529 | |
| 6987 | 11년 전 | 3737 | ||
| 6986 |
잘살아보자
|
11년 전 | 1602 | |
| 6985 |
잘살아보자
|
11년 전 | 2486 | |
| 6984 | 11년 전 | 831 | ||
| 6983 |
천재조상훈
|
11년 전 | 1880 | |
| 6982 |
천재조상훈
|
11년 전 | 4514 | |
| 6981 |
천재조상훈
|
11년 전 | 1644 | |
| 6980 |
|
11년 전 | 1894 | |
| 6979 |
|
11년 전 | 768 | |
| 6978 |
잘살아보자
|
11년 전 | 1159 | |
| 6977 |
잘살아보자
|
11년 전 | 1476 | |
| 6976 |
잘살아보자
|
11년 전 | 1586 | |
| 6975 |
천재조상훈
|
11년 전 | 1496 | |
| 6974 |
잘살아보자
|
11년 전 | 2238 | |
| 6973 |
잘살아보자
|
11년 전 | 1166 | |
| 6972 |
잘살아보자
|
11년 전 | 3075 | |
| 6971 |
잘살아보자
|
11년 전 | 3281 | |
| 6970 |
잘살아보자
|
11년 전 | 1854 | |
| 6969 |
잘살아보자
|
11년 전 | 4787 | |
| 6968 | 11년 전 | 9914 | ||
| 6967 |
|
11년 전 | 2646 | |
| 6966 |
|
11년 전 | 1119 | |
| 6965 | 11년 전 | 3268 | ||
| 6964 | 11년 전 | 2591 | ||
| 6963 | 11년 전 | 2109 | ||
| 6962 |
star3840
|
11년 전 | 1024 | |
| 6961 | 11년 전 | 4251 | ||
| 6960 |
|
11년 전 | 740 | |
| 6959 | 11년 전 | 1267 | ||
| 6958 |
|
11년 전 | 1683 | |
| 6957 | 11년 전 | 1910 | ||
| 6956 |
잘살아보자
|
11년 전 | 1859 | |
| 6955 | 11년 전 | 4634 | ||
| 6954 | 11년 전 | 1637 | ||
| 6953 |
잘살아보자
|
11년 전 | 887 | |
| 6952 |
잘살아보자
|
11년 전 | 2056 | |
| 6951 | 11년 전 | 1619 | ||
| 6950 | 11년 전 | 2621 | ||
| 6949 |
잘살아보자
|
11년 전 | 897 | |
| 6948 | 11년 전 | 1564 | ||
| 6947 | 11년 전 | 1475 | ||
| 6946 | 11년 전 | 1623 | ||
| 6945 | 11년 전 | 1232 | ||
| 6944 | 11년 전 | 1196 | ||
| 6943 | 11년 전 | 1238 | ||
| 6942 | 11년 전 | 1592 | ||
| 6941 | 11년 전 | 1666 | ||
| 6940 | 11년 전 | 1761 | ||
| 6939 | 11년 전 | 1672 | ||
| 6938 | 11년 전 | 1954 | ||
| 6937 | 11년 전 | 1165 | ||
| 6936 | 11년 전 | 1365 | ||
| 6935 | 11년 전 | 1310 | ||
| 6934 | 11년 전 | 1476 | ||
| 6933 | 11년 전 | 1987 | ||
| 6932 | 11년 전 | 1548 | ||
| 6931 | 11년 전 | 1552 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기