位置: IT常识 - 正文

串口多字节数据的接收(串口发送字节数据的数据格式是什么)

编辑:rootadmin
这次设计一个可以接收多字节(通过修改例化时的位宽实现)的串口接收模块。 当接收到9个字节的数据,但是我们只需要8个字节的数据时候,我们需要的是前八位的数据还是后八位的数据我们无法确定。 所以我们需要设定一种传输协议,这种协议我们可以自定义规则。我们就设定前缀为8'h55+8'hA5,后缀为8'hF0 ...

推荐整理分享串口多字节数据的接收(串口发送字节数据的数据格式是什么),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:串口最后多一个字节ff,串口发送多字节数据,串口发送多字节数据,串口通信一次几个字节,串口如果接收多字节数据fpga,串口一次最多读取多少字节,串口通信一次几个字节,串口如果接收多字节数据fpga,内容如对您有帮助,希望把文章链接给更多的朋友!

这次设计一个可以接收多字节(通过修改例化时的位宽实现)的串口接收模块。

串口多字节数据的接收(串口发送字节数据的数据格式是什么)

当接收到9个字节的数据,但是我们只需要8个字节的数据时候,我们需要的是前八位的数据还是后八位的数据我们无法确定。

所以我们需要设定一种传输协议,这种协议我们可以自定义规则。我们就设定前缀为8'h55+8'hA5,后缀为8'hF0的一串数据即为我们需要的数据。

1、状态机的设定

2、需要的模块(1) 8位串口接收模块`timescale 1ns / 1ps//////////////////////////////////////////////////////////////////////////////////// Company: // Engineer: Lclone// // Create Date: 2022/12/16 15:37:44// Design Name: uart_byte_rx// Module Name: uart_byte_rx// Project Name: uart_byte_rx// Target Devices: // Tool Versions: // Description: 8位串口接收模块// // Dependencies: // // Revision:// Revision 0.01 - File Created// Additional Comments:// //////////////////////////////////////////////////////////////////////////////////module uart_byte_rx # ( parameter RX_BAUD = 9600,//波特率 parameter CLK_FQC = 50_000_000,//模块时钟频率 parameter BAUD_CNT = CLK_FQC/RX_BAUD)//模块每波特需要计数的次数(设置此端口方便仿真用) ( input Clk,//时钟频率接口 input Rst_n,//复位接口 input Uart_rx,//串口接收接口 output reg [7:0] Data,//接收到的数据接口 output reg Rx_done//接收完成信号 ); reg uart_rx_r;//延一拍 reg uart_rx_rr;//延两拍 reg receiv_begin;//接收开始信号 reg receiv_flag;//接收状态信号 reg [ 3:0] state;//状态机寄存器 reg [15:0] baud_cnt;//波及计数器 reg [ 3:0] sampel_cnt;//采样计数器 reg sampel_en;//采样使能 reg sampel_ref;//样本寄存器 reg [ 3:0] acc;//累加寄存器 reg [ 3:0] bit_cnt;//数据位寄存器 always @(posedge Clk) begin //延两拍为下降沿捕获 uart_rx_r <= Uart_rx; uart_rx_rr <= uart_rx_r; end always @(posedge Clk or negedge Rst_n) begin//接收信号发生 if(Rst_n == 0) receiv_begin <= 0; else if(state == 0 & uart_rx_rr & ~uart_rx_r) receiv_begin <= 1'b1; else receiv_begin <= 0; end always @(posedge Clk or negedge Rst_n) begin//状态机 if(Rst_n == 0) begin state <= 0; sampel_ref <= 8'b0; acc <= 8'b0; Data <= 8'b0; end else case(state) 0: //空闲状态 if(receiv_begin == 1) state <= 3'd1; else state <= 0; 1: begin//抽样状态 if(sampel_en == 1) begin sampel_ref <= Uart_rx; state <= 3'd2; end else state <= 3'b1; end 2: begin//数据判断状态 acc <= acc + sampel_ref; if(sampel_cnt == 7) begin if(acc >= 4) begin Data[7] <= 1'b1; state <= 3'd3;acc <= 8'b0; end else begin Data[7] <= 0; state <= 3'd3;acc <= 8'b0; end end else state <= 3'd1; end 3: begin//数据移位状态 if(bit_cnt < 8) begin Data <= Data >> 1; state <= 3'd1; end else state <= 0; end default:; endcase end always @(posedge Clk or negedge Rst_n) begin//接收进行标志 if(Rst_n == 0) receiv_flag <= 0; else if(receiv_begin == 1) receiv_flag <= 1'b1; else if(bit_cnt == 9 & baud_cnt == BAUD_CNT/9*8) //这里设置为记到BAUD_CNT/9*8是为了让Rx_done信号提前一点产生,避免因为Rx_done出现过晚,导致错过下一个起始位的下降沿。后面和其相同的条件判断,也是因为相同原因设置的。 receiv_flag <= 1'b0; end always @(posedge Clk or negedge Rst_n) begin//波特计数 if(Rst_n == 0) baud_cnt <= 0; else if(receiv_flag == 1) begin if(baud_cnt == BAUD_CNT - 1) baud_cnt <= 0; else baud_cnt <= baud_cnt + 1'b1; end else baud_cnt <= 0; end always @(posedge Clk or negedge Rst_n) begin//采样计数 if(Rst_n == 0) begin sampel_cnt <= 0; sampel_en <= 0; end else if(receiv_flag == 1) begin case(baud_cnt) BAUD_CNT/9*1-1 : begin sampel_cnt <= 0; sampel_en <=1; end BAUD_CNT/9*2-1 : begin sampel_cnt <= 1; sampel_en <=1; end BAUD_CNT/9*3-1 : begin sampel_cnt <= 2; sampel_en <=1; end BAUD_CNT/9*4-1 : begin sampel_cnt <= 3; sampel_en <=1; end BAUD_CNT/9*5-1 : begin sampel_cnt <= 4; sampel_en <=1; end BAUD_CNT/9*6-1 : begin sampel_cnt <= 5; sampel_en <=1; end BAUD_CNT/9*7-1 : begin sampel_cnt <= 6; sampel_en <=1; end BAUD_CNT/9*8-1 : begin sampel_cnt <= 7; sampel_en <=1; end BAUD_CNT/9*9-1 : sampel_cnt <= 0; default:sampel_en <=0; endcase end end always @(posedge Clk or negedge Rst_n) begin//数据位计数 if(Rst_n == 0) bit_cnt <= 0; else if(bit_cnt == 9 & baud_cnt == BAUD_CNT/9*8) bit_cnt <= 0; else if(baud_cnt == BAUD_CNT - 1) bit_cnt <= bit_cnt + 1'b1; end always @(posedge Clk or negedge Rst_n) begin//接收完成信号产生 if(Rst_n == 0) Rx_done <= 0; else if(bit_cnt == 9 & baud_cnt == BAUD_CNT/9*8) Rx_done <= 1'b1; else Rx_done <= 0; endendmodule3、设计的模块代码`timescale 1ns / 1ps//////////////////////////////////////////////////////////////////////////////////// Company: // Engineer: // // Create Date: 2022/12/25 00:26:10// Design Name: // Module Name: uart_bytes_rx// Project Name: // Target Devices: // Tool Versions: // Description: // // Dependencies: // // Revision:// Revision 0.01 - File Created// Additional Comments:// //////////////////////////////////////////////////////////////////////////////////module uart_bytes_rx#(parameterDATA_WIDTH = 64,//数据位宽parameterPREFIX1 = 8'h55,//前缀1parameterPREFIX2 = 8'hA5,//前缀2parameterENDINGS = 8'hF0)//后缀(input Clk,//时钟信号input Rst_n,//复位信号input Uart_rx,//串口接收端口output reg[DATA_WIDTH-1-8*3:0] Bytes_data,//多字节数据端口output reg Bytes_Rx_done//多字节接收完成);reg[2:0]state;//状态机寄存器reg[DATA_WIDTH-1:0]bytes_data_reg;//多字节数据接收寄存器wire[7:0]rx_data_reg;//8位数据接收寄存器wireRx_done;//8位数据接收完成信号 uart_byte_rx # ( .RX_BAUD (115200),//波特率 .CLK_FQC (50_000_000))//时钟频率uart_byte_rx_inst ( .Clk (Clk),//时钟 .Rst_n (Rst_n),//复位 .Uart_rx (Uart_rx),//串口接收端口 .Data (rx_data_reg),//8位数据端口 .Rx_done (Rx_done)//8位数据接收完成 );always @(posedge Clk or negedge Rst_n) begin//状态机if(Rst_n == 0) beginstate <= 0;bytes_data_reg <= 0;Bytes_Rx_done <= 0;Bytes_data <= 0;end else case(state)0:beginif(Rx_done) beginbytes_data_reg[DATA_WIDTH-1:DATA_WIDTH-1-7] <= rx_data_reg;//数据装载state <= 3'd1;end else beginstate <= 0;Bytes_Rx_done <= 0;endend1:beginif(bytes_data_reg[DATA_WIDTH-1:DATA_WIDTH-1-7] == ENDINGS && bytes_data_reg[15:8] ==PREFIX2 && bytes_data_reg[7:0] ==PREFIX1)//数据协议判断 beginBytes_data <= bytes_data_reg[DATA_WIDTH-1-8:16];state <= 1'b0;Bytes_Rx_done <= 1'b1;bytes_data_reg <= 0; end elsestate <= 3'd2;end2:beginbytes_data_reg <= bytes_data_reg >> 8;//数据移位state <= 0;endendcaseendendmodule4、仿真验证(1)仿真激励文件`timescale 1ns / 1ps//////////////////////////////////////////////////////////////////////////////////// Company: // Engineer: // // Create Date: 2022/12/26 16:14:35// Design Name: // Module Name: uart_bytes_rx_tb// Project Name: // Target Devices: // Tool Versions: // Description: // // Dependencies: // // Revision:// Revision 0.01 - File Created// Additional Comments:// //////////////////////////////////////////////////////////////////////////////////module uart_bytes_rx_tb(); reg CLK_50M; reg RST_N; wire [39:0] Bytes_data; reg Uart_rx; wire Bytes_Rx_done; uart_bytes_rx # ( .DATA_WIDTH (64)) uart_bytes_rx_inst ( .Clk (CLK_50M), .Rst_n (RST_N), .Uart_rx (Uart_rx), .Bytes_data (Bytes_data), .Bytes_Rx_done (Bytes_Rx_done) ); defparamuart_bytes_rx_inst.uart_byte_rx_inst.BAUD_CNT = 50; always #10 CLK_50M <= ~CLK_50M; initial begin CLK_50M <= 1'b0; RST_N <= 1'b0; Uart_rx <= 1'b1; #100 RST_N <= 1'b1; #20data_deliver(8'h55); #100data_deliver(8'hA5); #100data_deliver(8'h01); #100data_deliver(8'h23); #100data_deliver(8'h45); #100data_deliver(8'h67); #100data_deliver(8'h89); #100data_deliver(8'hf0); #100 $stop; endtask data_deliver;input [7:0]test_data;beginUart_rx <= 1'b0;#1000 Uart_rx <= test_data[0];#1000 Uart_rx <= test_data[1];#1000 Uart_rx <= test_data[2];#1000 Uart_rx <= test_data[3];#1000 Uart_rx <= test_data[4];#1000 Uart_rx <= test_data[5];#1000 Uart_rx <= test_data[6];#1000 Uart_rx <= test_data[7];#1000 Uart_rx <= 1'b1;#1000;endendtaskendmodule(2)仿真结果

5、应用实例

我们把它应用为一个通过接收电脑串口发送的数据从而改变8位LED每位是否闪烁和闪烁的周期的程序。

top.v`timescale 1ns / 1psmodule Top( inputSclk,inputRst_n,inputUart_rx,output[7:0]LED);wire [23:0]Bytes_data;wireBytes_Rx_done;uart_bytes_rx# ( .DATA_WIDTH (48),.PREFIX1(8'h55),.PREFIX2 (8'hA5),.ENDINGS (8'hF0))uart_bytes_rx_inst(.Clk(Sclk),.Rst_n(Rst_n),.Uart_rx(Uart_rx),.Bytes_data(Bytes_data),.Bytes_Rx_done(Bytes_Rx_done));LED_6LED_6_inst(.SCLK(Sclk),.RST_N(Rst_n),.CTRL_IN(Bytes_data[7:0]),.Time(Bytes_data[23:8]),.LED(LED) );endmoduleuart_bytes_rx.v`timescale 1ns / 1psmodule uart_bytes_rx#(parameterDATA_WIDTH = 64,//数据位宽parameterPREFIX1 = 8'h55,//前缀1parameterPREFIX2 = 8'hA5,//前缀2parameterENDINGS = 8'hF0)//后缀(input Clk,//时钟信号input Rst_n,//复位信号input Uart_rx,//串口接收端口output reg[DATA_WIDTH-1-8*3:0] Bytes_data,//多字节数据端口output reg Bytes_Rx_done//多字节接收完成);reg[2:0]state;//状态机寄存器reg[DATA_WIDTH-1:0]bytes_data_reg;//多字节数据接收寄存器wire[7:0]rx_data_reg;//8位数据接收寄存器wireRx_done;//8位数据接收完成信号 uart_byte_rx # ( .RX_BAUD (115200),//波特率 .CLK_FQC (50_000_000))//时钟频率uart_byte_rx_inst ( .Clk (Clk),//时钟 .Rst_n (Rst_n),//复位 .Uart_rx (Uart_rx),//串口接收端口 .Data (rx_data_reg),//8位数据端口 .Rx_done (Rx_done)//8位数据接收完成 );always @(posedge Clk or negedge Rst_n) begin//状态机if(Rst_n == 0) beginstate <= 0;bytes_data_reg <= 0;Bytes_Rx_done <= 0;Bytes_data <= 0;end else case(state)0:beginif(Rx_done) beginbytes_data_reg[DATA_WIDTH-1:DATA_WIDTH-1-7] <= rx_data_reg;//数据装载state <= 3'd1;end else beginstate <= 0;Bytes_Rx_done <= 0;endend1:beginif(bytes_data_reg[DATA_WIDTH-1:DATA_WIDTH-1-7] == ENDINGS && bytes_data_reg[15:8] ==PREFIX2 && bytes_data_reg[7:0] ==PREFIX1)//数据协议判断 beginBytes_data <= bytes_data_reg[DATA_WIDTH-1-8:16];state <= 1'b0;Bytes_Rx_done <= 1'b1;bytes_data_reg <= 0; end elsestate <= 3'd2;end2:beginbytes_data_reg <= bytes_data_reg >> 8;//数据移位state <= 0;endendcaseendendmoduleuart_byte_rx.v`timescale 1ns / 1psmodule uart_byte_rx # ( parameter RX_BAUD = 9600, parameter CLK_FQC = 50_000_000, parameter BAUD_CNT = CLK_FQC/RX_BAUD) ( input Clk, input Rst_n, input Uart_rx, output reg [7:0] Data, output reg Rx_done ); reg uart_rx_r; reg uart_rx_rr; reg receiv_begin; reg receiv_flag; reg [ 3:0] state; reg [15:0] baud_cnt; reg [ 3:0] sampel_cnt; reg sampel_en; reg sampel_ref; reg [ 3:0] acc; reg [ 3:0] bit_cnt; always @(posedge Clk) begin uart_rx_r <= Uart_rx; uart_rx_rr <= uart_rx_r; end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) receiv_begin <= 0; else if(state == 0 & uart_rx_rr & ~uart_rx_r) receiv_begin <= 1'b1; else receiv_begin <= 0; end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) begin state <= 0; sampel_ref <= 8'b0; acc <= 8'b0; Data <= 8'b0; end else case(state) 0: if(receiv_begin == 1) state <= 3'd1; else state <= 0; 1: begin if(sampel_en == 1) begin sampel_ref <= Uart_rx; state <= 3'd2; end else state <= 3'b1; end 2: begin acc <= acc + sampel_ref; if(sampel_cnt == 7) begin if(acc >= 4) begin Data[7] <= 1'b1; state <= 3'd3;acc <= 8'b0; end else begin Data[7] <= 0; state <= 3'd3;acc <= 8'b0; end end else state <= 3'd1; end 3: begin if(bit_cnt < 8) begin Data <= Data >> 1; state <= 3'd1; end else state <= 0; end default:; endcase end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) receiv_flag <= 0; else if(receiv_begin == 1) receiv_flag <= 1'b1; else if(bit_cnt == 9 & baud_cnt == BAUD_CNT/9*8) receiv_flag <= 1'b0; end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) baud_cnt <= 0; else if(receiv_flag == 1) begin if(baud_cnt == BAUD_CNT - 1) baud_cnt <= 0; else baud_cnt <= baud_cnt + 1'b1; end else baud_cnt <= 0; end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) begin sampel_cnt <= 0; sampel_en <= 0; end else if(receiv_flag == 1) begin case(baud_cnt) BAUD_CNT/9*1-1 : begin sampel_cnt <= 0; sampel_en <=1; end BAUD_CNT/9*2-1 : begin sampel_cnt <= 1; sampel_en <=1; end BAUD_CNT/9*3-1 : begin sampel_cnt <= 2; sampel_en <=1; end BAUD_CNT/9*4-1 : begin sampel_cnt <= 3; sampel_en <=1; end BAUD_CNT/9*5-1 : begin sampel_cnt <= 4; sampel_en <=1; end BAUD_CNT/9*6-1 : begin sampel_cnt <= 5; sampel_en <=1; end BAUD_CNT/9*7-1 : begin sampel_cnt <= 6; sampel_en <=1; end BAUD_CNT/9*8-1 : begin sampel_cnt <= 7; sampel_en <=1; end BAUD_CNT/9*9-1 : sampel_cnt <= 0; default:sampel_en <=0; endcase end end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) bit_cnt <= 0; else if(bit_cnt == 9 & baud_cnt == BAUD_CNT/9*8) bit_cnt <= 0; else if(baud_cnt == BAUD_CNT - 1) bit_cnt <= bit_cnt + 1'b1; end always @(posedge Clk or negedge Rst_n) begin if(Rst_n == 0) Rx_done <= 0; else if(bit_cnt == 9 & baud_cnt == BAUD_CNT/9*8) Rx_done <= 1'b1; else Rx_done <= 0; endendmoduleLED_6.v`timescale 1ns / 1psmodule LED_6( input SCLK, input RST_N, input [ 7:0] CTRL_IN, input [15:0] Time, output reg [ 7:0] LED ); parameter DELAY_10US = 500; parameter COUNT_10MS = 1000; reg [8:0] count_10us; reg [15:0] count_time;reg led_flag; always @(posedge SCLK or negedge RST_N) begin if(RST_N == 0) count_10us <= 0; else if(count_10us == DELAY_10US - 1) count_10us <= 0; else count_10us <= count_10us + 1'b1; end always @(posedge SCLK or negedge RST_N) begin if(RST_N == 0) count_time <= 0; else if(count_time == Time - 1) count_time <= 0; else if(count_10us == DELAY_10US - 1) count_time <= count_time + 1'b1; endalways @(posedge SCLK or negedge RST_N) begin if(RST_N == 0) led_flag <= 0; else if(count_time == COUNT_10MS - 1) led_flag <= ~led_flag; end always @(posedge SCLK or negedge RST_N) beginif(RST_N == 0)LED <= 0;else if(count_time == COUNT_10MS - 1 & led_flag == 1)LED <= CTRL_IN;else if(count_time == COUNT_10MS - 1 & led_flag == 0)LED <= 0; end endmodule
本文链接地址:https://www.jiuchutong.com/zhishi/310408.html 转载请保留说明!

上一篇:OpenGL 伽马线(opengl加阴影)

下一篇:帝国cms要授权吗(帝国cms要授权吗知乎)

  • 好太太油烟机怎么样质量好吗(好太太油烟机怎么样)(好太太油烟机怎么安装)

    好太太油烟机怎么样质量好吗(好太太油烟机怎么样)(好太太油烟机怎么安装)

  • 苹果手机怎么进入dfu模式(苹果手机怎么进p站)

    苹果手机怎么进入dfu模式(苹果手机怎么进p站)

  • 小米mix2s前摄像头失效(小米mix2s前摄像头更换视频教程)

    小米mix2s前摄像头失效(小米mix2s前摄像头更换视频教程)

  • 美团要不要加入乐跑计划

    美团要不要加入乐跑计划

  • 快手下载到本地的视频在哪里(快手下载到本地的图标怎么去掉)

    快手下载到本地的视频在哪里(快手下载到本地的图标怎么去掉)

  • vivoy97是什么时候上市的(vivoy97哪年上市的)

    vivoy97是什么时候上市的(vivoy97哪年上市的)

  • 小米10标准版多少倍变焦(小米10 标准版)

    小米10标准版多少倍变焦(小米10 标准版)

  • flash文字逐字出现遮罩(flash文字逐字出现动画效果)

    flash文字逐字出现遮罩(flash文字逐字出现动画效果)

  • 退格键变成了删除键(退格键变成空格)

    退格键变成了删除键(退格键变成空格)

  • 抖音拍摄原声太小怎么办(抖音视频原声太小怎么办)

    抖音拍摄原声太小怎么办(抖音视频原声太小怎么办)

  • 极速退款特权能用几次(极速退款选项)

    极速退款特权能用几次(极速退款选项)

  • 华为p40pro重量多少克(华为p40proplus重量)

    华为p40pro重量多少克(华为p40proplus重量)

  • 手机电池温度45度正常吗(手机电池温度45度)

    手机电池温度45度正常吗(手机电池温度45度)

  • 腾达ac7是真千兆路由器吗(腾达ac8是不是真千兆)

    腾达ac7是真千兆路由器吗(腾达ac8是不是真千兆)

  • 微信支付电费多久到账(微信支付电费多久来电)

    微信支付电费多久到账(微信支付电费多久来电)

  • realme Q上市时间(realmeq系列新机)

    realme Q上市时间(realmeq系列新机)

  • 健康三环手表意思(三环手环的意义)

    健康三环手表意思(三环手环的意义)

  • 手机显示未接通啥意思(手机老是显示未接电话)

    手机显示未接通啥意思(手机老是显示未接电话)

  • wifisd卡怎么导出照片(wi-fi sd卡)

    wifisd卡怎么导出照片(wi-fi sd卡)

  • 怎么改电费接收手机号(如何更改交电费的用户)

    怎么改电费接收手机号(如何更改交电费的用户)

  • 新人怎么玩快手(新人怎么玩快手卖衣服)

    新人怎么玩快手(新人怎么玩快手卖衣服)

  • qq退群别人会知道嘛(qq里退群会显示给所有人吗)

    qq退群别人会知道嘛(qq里退群会显示给所有人吗)

  • 华为nova5pro支持无线充电吗(华为nova5pro支持快充吗)

    华为nova5pro支持无线充电吗(华为nova5pro支持快充吗)

  • 手机调时间在哪里调(手机调时间在哪个功能里面)

    手机调时间在哪里调(手机调时间在哪个功能里面)

  • 充电宝给手机充电慢(充电宝给手机充一晚上可以吗)

    充电宝给手机充电慢(充电宝给手机充一晚上可以吗)

  • 旺旺禁言怎么解除(旺旺禁言多久恢复)

    旺旺禁言怎么解除(旺旺禁言多久恢复)

  • Echarts图表自适应?你可以这样做(echarts图大小设置)

    Echarts图表自适应?你可以这样做(echarts图大小设置)

  • 增值税电子发票查询平台
  • 白酒消费税税率多少钱一吨
  • 不含税销售额计算公式理解
  • 财税通财务软件怎么下载
  • 纳税标准怎么算
  • 小规模纳税人增值税优惠政策2023
  • 企业文化事业建设费计算
  • 一般纳税人销项税和进项税如何抵扣
  • 向香港公司支付服务费税率
  • 交通运输企业的装卸业务的全部费用
  • 签证费怎么支付
  • 承兑汇票怎么委托收款
  • 五险一金账务处理流程图
  • 预提退货实际发生时账务处理
  • 营业执照印花税减免政策
  • 税务登记号就是发票吗
  • 小规模纳税人应纳税额的计算
  • 收到转账支票 转给下一家
  • 发票进项抵扣有什么用
  • 典当行的账务处理会计分录大全
  • 电商企业收入成本如何核算
  • 基本社会保障性缴款包括什么
  • 小型微利企业应纳税所得额300万
  • 向投资者分配现金股利会计分录?
  • 改变资金用途的说明
  • 无形资产入账摊销
  • 工厂院子里的地图怎么画
  • 无法登陆wifi怎么登陆路由器
  • PHP:Memcached::__construct()的用法_Memcached类
  • 商业折扣影响税费吗
  • 未结算未取得发票怎么办
  • ros call
  • 增值税普通发票和专用发票有什么区别
  • 最贵的苹果平板
  • 冰河湖怎么去
  • 个人出租商用房个人所得税
  • vue2+element-plus 密码校验及动态校验
  • thinkphp 模块
  • 小规模纳税人开专票需要交税吗
  • cuda安装步骤
  • ai训练流程
  • spring boot s
  • idea搭建web开发环境
  • php导出带样式的数据库
  • 公司购买办公用品会计分录
  • 企业待报解预算收入的分录
  • 计提预付账款会计分录
  • 车辆购置税收优惠
  • 购买固定资产的运费计入什么科目
  • 财税人员岗位职责
  • 以前年度费用未入账,现可以入账吗?
  • 销项税多做了怎么冲
  • 物流公司的会计怎么样
  • 人力资源劳务费计入什么科目
  • 定金帐务处理
  • 收到税务局退增值税怎么入账
  • 财务费用包括什么项目
  • 公司软件使用制度
  • 销项减进项税额
  • 专家评审费需要上税吗
  • 农业生态有限公司成立条件
  • 私营企业固定资产法律制度
  • 在sp_executesql中使用like字句的方法
  • 快速插入大量数据的asp.net代码(Sqlserver)
  • windows怎么用
  • vista win
  • ntdll.dll no matching
  • vc6运行程序
  • video for windows是什么
  • win7窗口大小怎么设置
  • 新手如何入门
  • 何为黄金茶
  • c++ not1
  • Python 中urls.py:URL dispatcher(路由配置文件)详解
  • JavaScript中的方法名不区分大小写
  • js颜色表
  • 重庆市电子税务局官网登录入口注册
  • "贴现"是什么业务,都涉及哪些费用?
  • 哈尔滨银行网上银行怎么开通
  • 伴生矿和伴采矿的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设