SPAttachmentCollection class
Representa a coleção de anexos para um item de lista.
Inheritance hierarchy
System.Object
Microsoft.SharePoint.SPAttachmentCollection
Namespace: Microsoft.SharePoint
Assembly: Microsoft.SharePoint (in Microsoft.SharePoint.dll)
Syntax
'Declaração
Public Class SPAttachmentCollection _
Implements ICollection, IEnumerable
'Uso
Dim instance As SPAttachmentCollection
public class SPAttachmentCollection : ICollection,
IEnumerable
Comentários
Use a propriedade Attachments da classe SPListItem para retornar a coleção de anexos para um item de lista. Para criar um anexo, use o método Add
Use um indexador para retornar o nome de um único anexo da coleção. Por exemplo, supondo que a coleção é atribuído a uma variável chamada collAttachments , use collAttachments[index] em C# ou deindexde collAttachments() em Visual Basic, onde index é o número de índice do anexo da coleção.
Examples
O exemplo de código a seguir mostra como anexar todos os arquivos de uma biblioteca de documentos de documentos compartilhados para o primeiro item de lista dentro de uma lista que aparece em cada subsite sob o site.
O método Add da classe SPAttachmentCollection requer que você passe o arquivo como um parâmetro em formato binário. Portanto, o exemplo usa o método OpenBinary da classe SPFile para abrir cada arquivo dentro da pasta em formato binário.
Dim oSiteCollection As SPSite = SPContext.Current.Site
Dim collWebsites As SPWebCollection = oSiteCollection.AllWebs
Dim oWebsite As SPWeb = collWebsites("Site_Name")
Dim oFolder As SPFolder = oWebsite.Folders("Shared Documents")
For Each oWebsiteNext As SPWeb In collWebsites
Dim oList As SPList = oWebsiteNext.Lists("List_Name")
Dim collItem As SPListItemCollection = oList.Items
Dim oListItem As SPListItem = collItem(0)
Dim collAttachments As SPAttachmentCollection = oListItem.Attachments
Dim collFiles As SPFileCollection = oFolder.Files
For Each oFile As SPFile In collFiles
Dim strFileName As String = oFile.Name
Dim binFile As Byte() = oFile.OpenBinary()
collFiles.Add(strFileName, binFile)
Next oFile
oListItem.Update()
oWebsiteNext.Dispose()
Next oWebsiteNext
oWebsite.Dispose()
SPSite oSiteCollection = SPContext.Current.Site;
SPWebCollection collWebsites = oSiteCollection.AllWebs;
SPWeb oWebsite = collWebsites["Site_Name"];
SPFolder oFolder = oWebsite.Folders["Shared Documents"];
foreach (SPWeb oWebsiteNext in collWebsites)
{
SPList oList = oWebsiteNext.Lists["List_Name"];
SPListItemCollection collItem = oList.Items;
SPListItem oListItem = collItem[0];
SPAttachmentCollection collAttachments = oListItem.Attachments;
SPFileCollection collFiles = oFolder.Files;
foreach (SPFile oFile in collFiles)
{
string strFileName = oFile.Name;
byte[] binFile = oFile.OpenBinary();
collFiles.Add(strFileName, binFile);
}
oListItem.Update();
oWebsiteNext.Dispose();
}
oWebsite.Dispose();
Dica
Determinados objetos implementam a interface IDisposable , e você deve evitar reter esses objetos na memória depois que eles não são mais necessários. Para obter informações sobre boas práticas de codificação, consulte Disposing Objects.
Thread safety
Any public static (Shared in Visual Basic) members of this type are thread safe. Any instance members are not guaranteed to be thread safe.