在C#中将Excel图形导出为Word作为图形

时间:2019-03-01 11:01:48

标签: c# excel office-interop

是否可以以编程方式将Excel中的图形作为图形复制/导出到Word文档?这将包括:

import wx


class MainFrame(wx.Frame):

    def __init__(self, *args, **kwargs):
        super(MainFrame, self).__init__(None, *args, **kwargs)
        self.Title = 'premier app (Menu+2windows)'
        self.SetMenuBar(MenuBar(self))
        self.ToolBar = MainToolbar(self)
        self.status_bar = StatusBar(self).status_bar
        self.Bind(wx.EVT_CLOSE, self.on_quit_click)
        panel = MainPanel(self)
        sizer = wx.BoxSizer()
        sizer.Add(panel)
        self.SetSizerAndFit(sizer)
        self.Centre()
        self.Show()

    def on_quit_click(self, event):

        del event
        wx.CallAfter(self.Destroy)


class MainPanel(wx.Panel):

    def __init__(self, parent):
        wx.Frame.__init__(self, parent,size = (500,500))
        self.splitter = wx.SplitterWindow(self, -1, size = (500,500))

# 1er panel 
        pan1 = wx.Window(self.splitter, style=wx.BORDER_SUNKEN)
        pan1.SetBackgroundColour("yellow")
        wx.StaticText(pan1, -1)


#2em panel
        pan2 = wx.Window(self.splitter, style=wx.BORDER_SUNKEN)
        pan2.SetBackgroundColour("blue")
        wx.StaticText(pan2, -1)
        self.splitter.SplitVertically(pan1, pan2, 100)


class MenuBar(wx.MenuBar):
    """creation de menu."""
    def __init__(self, parent, *args, **kwargs):
        super(MenuBar, self).__init__(*args, **kwargs)
        #  menu
        File_menu = wx.Menu()
        Edit_menu = wx.Menu()
        View_menu = wx.Menu()
        Help_menu = wx.Menu()

        self.Append(File_menu, '&File')
        self.Append(Edit_menu, '&Edit')
        self.Append(View_menu, '&View')
        self.Append(Help_menu, '&Help')

        quit_menu_item = wx.MenuItem(File_menu, wx.ID_EXIT)
        parent.Bind(wx.EVT_MENU, parent.on_quit_click, id=wx.ID_EXIT)
        open_menu_item = wx.MenuItem(File_menu, wx.ID_OPEN)
        parent.Bind(wx.EVT_MENU,self.on_open_file,id=wx.ID_OPEN)
        new_menu_item = wx.MenuItem(File_menu,wx.ID_NEW)
        File_menu.Append(open_menu_item)
        File_menu.Append(new_menu_item)
        File_menu.Append(quit_menu_item)

    def on_open_file (self, event):
        dlg = wx.FileDialog(self, message="Choose file", defaultDir = "D:/home/sarah/", defaultFile = "",\
                        wildcard = "", style=wx.FD_OPEN)
        if dlg.ShowModal() == wx.ID_OK:
            print(dlg.GetDirectory(), dlg.GetFilename())
        dlg.Destroy()

class MainToolbar(wx.ToolBar):
     def __init__(self, parent, *args, **kwargs):
        super(MainToolbar, self).__init__(parent, *args, **kwargs)



class StatusBar(object):
    def __init__(self, parent):
        self.status_bar = parent.CreateStatusBar()



if __name__ == '__main__':
    """Run the application."""
    screen_app = wx.App()
    main_frame = MainFrame()
    screen_app.MainLoop()

我曾尝试使用VBA和Java来执行此操作,但我只能以图表形式获得图表,这意味着质量不佳。我需要将其设置为“图形”格式,就像我只是进入excel并先按CTRL + C再按CTRL + V一样。

我认为,如果我能以某种方式使用 Microsoft.Office.Interop.Word Microsoft.Office.Interop.Excel ,则可能在C#中是可行的,但我没有以前用过C#。

有人知道这是否可能吗?它不一定必须使用C#,但我认为这可能是最合理的解决方案。

谢谢!

0 个答案:

没有答案