我需要在GH页面上显示目录内容。
更喜欢
所以,如果我的GH页面存储库中有一个FS:
http://github.com/[username]/[username].github.io/
:
script/
- app/
- core/
- init.js
- lib/
- Element.animate.js
- Object.overlay.js
- mod/
- anim/
- global/
- carousel/
- carousel.js
- global.js
- ext/
- cfgs.js
index.html
我希望每个目录网址都像往常一样索引,就像这样。
http://[username].github.io/script/
:
- app/
- lib/
- mod/
- ext/
http://[username].github.io/script/mod/anim/global/
:
- carousel/
- global.js
我唯一能想到的是首选项#2,编写或查找脚本以从GitHub Repo页面或我的FS上的本地Repo自动生成index.html。
答案 0 :(得分:6)
我也想这样做。我尝试将内容为.htaccess
的{{1}}文件上传到相关目录,但这不起作用。
所以,我使用你的选项#2,编写一个小的Python脚本来为目录生成一个索引文件文件。
Options +Indexes
答案 1 :(得分:4)
这种方式更好,它将进入子目录并为它们制作索引文件
""" Build index from directory listing
make_index.py </path/to/directory> [--header <header text>]
"""
from __future__ import print_function
import os.path, time
INDEX_TEMPLATE = r"""
<html>
<head>
<title>${header}</title>
<meta name="description" content="${header}"/>
</head>
<body>
<h2>Index of ${header}</h2>
<p>
<table>
<tbody>
<tr>
<th valign="top"><img src="${ROOTDIR}images/blank.gif"
alt="[ICO]"></th>
<th><a href="?C=N;O=D">Name</a></th>
<th><a href="?C=M;O=A">Last modified</a></th>
<th><a href="?C=S;O=A">Size</a></th>
<th><a href="?C=D;O=A">Description</a></th>
</tr>
<tr>
<th colspan="5"><hr></th>
</tr>
<tr>
<td valign="top"><img src=" "
alt="[PARENTDIR]"></td>
<td><a href="../">Parent Directory</a></td>
<td> </td>
<td align="right">-</td>
<td> </td>
</tr>
<tr>
<th colspan="5"><hr></th>
</tr>
% for name in dirnames:
<tr>
<td valign="top"><img src=" "
alt="[DIR]"></td>
<td><a href="${name}">${name}</a></td>
<td align="right">${time}</td>
<td align="right">-</td>
<td> </td>
</tr>
% endfor
% for name in filenames:
<tr>
<td valign="top"><img src=" "
alt="[DIR]"></td>
<td><a href="${name}">${name}</a></td>
<td align="right">${time}</td>
<td align="right">-</td>
<td> </td>
</tr>
% endfor
</p>
</tbody>
</table>
</body>
</html>
"""
EXCLUDED = ['index.html']
import os
import argparse
# May need to do "pip install mako"
from mako.template import Template
def fun(dir,rootdir):
print('Processing: '+dir)
filenames = [fname for fname in sorted(os.listdir(dir))
if fname not in EXCLUDED and os.path.isfile(dir+fname)]
dirnames = [fname for fname in sorted(os.listdir(dir))
if fname not in EXCLUDED ]
dirnames = [fname for fname in dirnames if fname not in filenames]
# header = os.path.basename(dir)
f = open(dir+'/index.html','w')
print(Template(INDEX_TEMPLATE).render(dirnames=dirnames,filenames=filenames, header=dir,ROOTDIR=rootdir,time=time.ctime(os.path.getctime(dir))),file=f)
f.close()
for subdir in dirnames:
try:
fun(dir+subdir+"/",rootdir+'../')
except:
pass
def main():
parser = argparse.ArgumentParser()
parser.add_argument("directory")
parser.add_argument("--header")
args = parser.parse_args()
fun(args.directory+'/','../')
if __name__ == '__main__':
main()
答案 2 :(得分:3)
如果您想要一个不需要任何更新的动态索引,我发现的唯一方法就是使用github contents api在客户端生成它。
这是一个简单的示例,可在项目的顶层目录中创建指向文件的链接。如果要使用此方法支持子目录,则必须递归地请求每个文件夹的内容。
<html>
<body>
<script>
(async () => {
const response = await fetch('https://api.github.com/repos/:user/:repo/contents/');
const data = await response.json();
let htmlString = '<ul>';
for (let file of data) {
htmlString += `<li><a href="${file.path}">${file.name}</a></li>`;
}
htmlString += '</ul>';
document.getElementsByTagName('body')[0].innerHTML = htmlString;
})()
</script>
<body>
</html>
Here's an example,在这里我用它来为我拥有的平面仓库创建一个简单的目录。
答案 3 :(得分:0)