我正在尝试从一堆文件中提取元数据。这些文件可以是图像,视频,也可以是任何类型。我想从文件中提取所有可用的元数据,而不管类型如何。我尝试使用WindowsAPICodePack
和Shell32
。我能够提取一堆属性,但是我需要文件中可用的“ Projection Type”元数据。但是WindowsAPICodePack
和Shell32
都无法提取相同的内容。有解决方案吗?
这是我尝试过的Shell 32
代码
List<string> arrHeaders = new List<string>();
List<Tuple<int, string, string>> attributes = new List<Tuple<int, string, string>>();
Shell32.Shell shell = new Shell32.Shell();
var strFileName = @"C:\Users\Admin\Google Drive\image.jpg";
Shell32.Folder objFolder = shell.NameSpace(System.IO.Path.GetDirectoryName(strFileName));
Shell32.FolderItem folderItem = objFolder.ParseName(System.IO.Path.GetFileName(strFileName));
for (int i = 0; i < short.MaxValue; i++)
{
string header = objFolder.GetDetailsOf(null, i);
if (String.IsNullOrEmpty(header))
break;
arrHeaders.Add(header);
}
// The attributes list below will contain a tuple with attribute index, name and value
// Once you know the index of the attribute you want to get,
// you can get it directly without looping, like this:
var Authors = objFolder.GetDetailsOf(folderItem, 20);
for (int i = 0; i < arrHeaders.Count; i++)
{
var attrName = arrHeaders[i];
var attrValue = objFolder.GetDetailsOf(folderItem, i);
var attrIdx = i;
attributes.Add(new Tuple<int, string, string>(attrIdx, attrName, attrValue));
Debug.WriteLine("{0}\t{1}: {2}", i, attrName, attrValue);
}
Console.ReadLine();
WindowsAPICodePack
的代码如下。
ShellObject file = ShellObject.FromParsingName(path);
var props = file.Properties.DefaultPropertyCollection;
var camera = file.Properties.GetProperty(SystemProperties.System.Photo.CameraModel);
答案 0 :(得分:-1)
好吧,经过一番搜索,我最终还是使用了ExifTool by Phil Harvey。
该工具在提取很多元数据方面非常有效,尤其是我特别需要的-'ProjectionType'。此属性用于检查上传的文件是否为360视频/图像。这几乎就是我最终得到的结果。
public List<Metadata> ExtractMetaDataExifTool(string filepath, string ExifToolPath)
{
#region ReadFromFile
string output = "";
var lstMetadata = new List<Metadata>();
using (var p = new Process())
{
// exiftool command
string toolPath = "";
toolPath += " -s ";
toolPath += "-fast -G -t -m -q -q -n ";
toolPath += "\"" + filepath + "\"";
System.Diagnostics.ProcessStartInfo startInfo = new System.Diagnostics.ProcessStartInfo();
startInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;
startInfo.FileName = "\"" + ExifToolPath + "\\exiftool.exe" + "\"";
startInfo.Arguments = toolPath;
startInfo.RedirectStandardOutput = true;
startInfo.UseShellExecute = false;
p.StartInfo = startInfo;
bool status = p.Start();
StringBuilder q = new StringBuilder();
while (!p.HasExited)
{
q.Append(p.StandardOutput.ReadToEnd());
}
output = q.ToString();
p.WaitForExit();
}
#endregion ReadFromFile
#region ExtractFileMetadataFromString
while (output.Length > 0)
{
int epos = output.IndexOf('\r');
if (epos < 0)
epos = output.Length;
string tmp = output.Substring(0, epos);
int tpos1 = tmp.IndexOf('\t');
int tpos2 = tmp.IndexOf('\t', tpos1 + 1);
if (tpos1 > 0 && tpos2 > 0)
{
string taggroup = tmp.Substring(0, tpos1);
++tpos1;
string tagname = tmp.Substring(tpos1, tpos2 - tpos1);
++tpos2;
string tagvalue = tmp.Substring(tpos2, tmp.Length - tpos2);
// special processing for tags with binary data
tpos1 = tagvalue.IndexOf(", use -b option to extract");
if (tpos1 >= 0)
tagvalue.Remove(tpos1, 26);
if (!string.IsNullOrEmpty(taggroup) && !string.IsNullOrEmpty(tagname) && !string.IsNullOrEmpty(tagvalue))
{
lstMetadata.Add(new Metadata
{
group = taggroup?.Trim(),
name = tagname?.Trim(),
value = tagvalue?.Trim()
});
}
}
// is \r followed by \n ?
if (epos < output.Length)
epos += (output[epos + 1] == '\n') ? 2 : 1;
output = output.Substring(epos, output.Length - epos);
}
#endregion ExtractFileMetadataFromString
return lstMetadata;
}