阅读器关闭时read的尝试无效

 public static SqlDataReader GetReader(string sql, SqlParameter paras)
        {

            using (SqlConnection connection = new SqlConnection(SqlConnectionString))
            {
                SqlCommand command = new SqlCommand(sql, connection);
                command.Parameters.Add(paras);
                connection.Open();
                return command.ExecuteReader(CommandBehavior.CloseConnection);
            }
        }

 

public static User GetUserByLoginId(string loginId)
        {
            string sql = "select * from users where loginId=@LoginId";
            int userStateId;
            int userRoleId;
            using (SqlDataReader reader = DBHelper.GetReader(sql, new SqlParameter("@LoginId", loginId)))
            {
                if (reader.Read())//在此发生异常
                  ........
            }
        }

如果把以上蓝色的代码改为

                try
            {
                SqlConnection connection = new SqlConnection(SqlConnectionString);
                SqlCommand command = new SqlCommand(sql, connection);
                command.Parameters.Add(paras);
                connection.Open();
                return command.ExecuteReader(CommandBehavior.CloseConnection);
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }

则正确,综上,发现是由于 using语句引起的,因为using的特性--"当在某个代码段中使用了类的实例,而希望无论因为什么原因,只要离开了这个代码段就自动调用这个类实例的Dispose。"在此处也就是说已经释放了所有的资源,包括connection、command这样当然不能的到打开状态的SqlDataReader对象!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 可以使用pywin32库中的"win32process"和"win32api"模块来关闭打开的pdf阅读器。首先,使用win32process模块获取进程ID,然后使用win32api模块的TerminateProcess函数来终止该进程。 具体示例如下: ``` import win32process import win32api # 获取进程ID pdf_reader_name = "AcroRd32.exe" process_list = win32process.EnumProcesses() for pid in process_list: try: handle = win32api.OpenProcess(win32con.PROCESS_QUERY_INFORMATION | win32con.PROCESS_VM_READ, False, pid) exe_name = win32process.GetModuleFileNameEx(handle, 0) if pdf_reader_name in exe_name: # 终止进程 win32api.TerminateProcess(handle, 0) break except: pass ``` 注意,在上面的示例中,"AcroRd32.exe" 代表Adobe Reader的进程名称,如果你使用的是其他阅读器,需要更改进程名称。 ### 回答2: 使用pywin32库可以通过以下步骤来关闭已打开的PDF阅读器: 1. 导入所需的模块和库: ```python import win32com.client import time ``` 2. 创建一个PDF阅读器对象: ```python adobe = win32com.client.Dispatch("AcroExch.App") ``` 3. 获取当前正在打开的PDF阅读器实例: ```python pdfs = win32com.client.Dispatch("AcroExch.App").GetRunningApp() ``` 4. 遍历PDF阅读器实例列表,逐个关闭已打开的PDF阅读器: ```python for pdf in pdfs: pdf.Exit() time.sleep(1) # 等待1秒钟以确保PDF阅读器已经完全关闭 ``` 完整的代码如下: ```python import win32com.client import time adobe = win32com.client.Dispatch("AcroExch.App") pdfs = win32com.client.Dispatch("AcroExch.App").GetRunningApp() for pdf in pdfs: pdf.Exit() time.sleep(1) ``` 这段代码通过AcroExch.App对象启动一个Adobe Acrobat Reader实例,并获取当前正在运行的所有Acrobat Reader实例。然后,使用`.Exit()`方法逐个退出每个已打开的实例。 最后,我们使用`time.sleep(1)`函数来等待1秒钟,以确保PDF阅读器完全关闭。这可以避免使用出现任何问题。 ### 回答3: 要使用pywin32关闭已打开的PDF阅读器,需要先安装pywin32库。可以通过以下步骤完成此操作: 1. 打开命令提示符或终端窗口,并使用命令`pip install pywin32`安装pywin32库。 2. 在Python脚本中导入所需的模块: ```python import win32gui import win32con ``` 3. 使用`win32gui.FindWindow`函数查找打开的PDF阅读器窗口的句柄。 ```python hwnd = win32gui.FindWindow(None, "PDF阅读器的窗口标题") ``` 这里的"PDF阅读器的窗口标题"是PDF阅读器打开窗口的标题,可以通过查看PDF阅读器窗口的属性获得。 4. 使用`win32gui.PostMessage`函数发送关闭窗口的消息。 ```python win32gui.PostMessage(hwnd, win32con.WM_CLOSE, 0, 0) ``` 完整的代码如下所示: ```python import win32gui import win32con def close_pdf_reader(): hwnd = win32gui.FindWindow(None, "PDF阅读器的窗口标题") if hwnd != 0: win32gui.PostMessage(hwnd, win32con.WM_CLOSE, 0, 0) print("已关闭PDF阅读器") else: print("未找到PDF阅读器窗口") close_pdf_reader() ``` 要注意的是,这段代码将关闭找到的第一个匹配的PDF阅读器窗口。如果有多个PDF阅读器窗口打开,可能需要更复杂的逻辑来决定要关闭哪个窗口。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值